前言:
#传入参数可以预防sql注入攻击,而$不行,这是缺点所在,非必须情况下,还请尽量使用#预编译的形式传入参数
一般都是先将String转成list或者数组,再用foreach去循环,类似这样(如果是list,collection=“list”,如果是单参数数组的,collection=“array”) #{users} 下面有类似场景使用

提供初学者 学习使用,记录笔记

一、简介
在SQL语法中如果我们想使用in的话直接可以像如下一样使用:

select * from HealthCoupon where useType in ( '4' , '3' )

但是如果在MyBatis中的使用in的话,像如下去做的话,肯定会报错:

Map<String, Object> selectByUserId(@Param("useType") String useType)

select * from HealthCoupon where useType in (#{useType,jdbcType=VARCHAR})

其中useType=“2,3”;这样的写法,看似很简单,但是MyBatis不支持这样操作,可以用$进行替换,如下方式即可运行

  Map<String, Object> selectByUserId(@Param("useType") String useType)<select id="selectByUserId" resultMap="BaseResultMap" parameterType="java.lang.String">select * from HealthCoupon where useType in (${useType,jdbcType=VARCHAR})</select>

#方式能够很大程度防止sql注入,$方式无法防止sql注入,所以还是推荐使用#方式,参考以下三种方式。

MyBatis中提供了foreach语句实现IN查询,foreach语法如下:

foreach语句中, collection属性的参数类型可以使:List、数组、map集合
​     collection: 必须跟mapper.java中@Param标签指定的元素名一样
​     item: 表示在迭代过程中每一个元素的别名,可以随便起名,但是必须跟元素中的#{}里面的名称一样。index:表示在迭代过程中每次迭代到的位置(下标)open:前缀, sql语句中集合都必须用小括号()括起来
​     close:后缀separator:分隔符,表示迭代时每个元素之间以什么分隔

(一)、selectByIdSet(List idList)
如果参数的类型是List, 则在使用时,collection属性要必须指定为 list

List<User> selectByIdSet(List idList);

<select id="selectByIdSet" resultMap="BaseResultMap">SELECT<include refid="Base_Column_List" />from t_userWHERE id IN<foreach collection="list" item="id" index="index" open="(" close=")" separator=",">#{id}</foreach>
</select>

(二)、List selectByIdSet(String[] idList)

如果参数的类型是Array,则在使用时,collection属性要必须指定为 array

List<User> selectByIdSet(String[] idList);
<select id="selectByIdSet" resultMap="BaseResultMap">SELECT<include refid="Base_Column_List" />from t_userWHERE id IN<foreach collection="array" item="id" index="index" open="(" close=")" separator=",">#{id}</foreach>
</select>

(三)、参数有多个时

当查询的参数有多个时,有两种方式可以实现,一种是使用@Param(“xxx”)进行参数绑定,另一种可以通过Map来传参数。

3.1 @Param(“xxx”)方式

List<User> selectByIdSet(@Param("name")String name, @Param("ids")String[] idList);
<select id="selectByIdSet" resultMap="BaseResultMap">SELECT<include refid="Base_Column_List" />from t_userWHERE  name=#{name,jdbcType=VARCHAR} and id IN<foreach collection="ids" item="id" index="index"open="(" close=")" separator=",">#{id}</foreach>
</select>

3.2 Map方式

Map<String, Object> params = new HashMap<String, Object>(2);
params.put("name", name);
params.put("idList", ids);
mapper.selectByIdSet(params);

<select id="selectByIdSet" resultMap="BaseResultMap">  select  <include refid="Base_Column_List" />  from t_user where name = #{name}and ID in  <foreach item="item" index="index" collection="idList" open="(" separator="," close=")">  #{item}  </foreach>
</select>

学习地址 本人所有文章只是自己记录 使用

[Java基础 持久层Mybatis] Mybatis使用IN语句查询相关推荐

  1. Java数据持久层框架 MyBatis之背景知识一

    对于MyBatis的学习而言,最好去MyBatis的官方文档:http://www.mybatis.org/mybatis-3/zh/index.html 对于语言的学习而言,马上上手去编程,多多练习 ...

  2. Java数据持久层框架 MyBatis之API学习六(Mapper XML 文件详解)

    对于MyBatis的学习而言,最好去MyBatis的官方文档:http://www.mybatis.org/mybatis-3/zh/index.html 对于语言的学习而言,马上上手去编程,多多练习 ...

  3. Java数据持久层框架 MyBatis之API学习八(Java API详解)

    对于MyBatis的学习而言,最好去MyBatis的官方文档:http://www.mybatis.org/mybatis-3/zh/index.html 对于语言的学习而言,马上上手去编程,多多练习 ...

  4. Java数据持久层框架 MyBatis之API学习五(Mapper XML 文件)

    对于MyBatis的学习而言,最好去MyBatis的官方文档:http://www.mybatis.org/mybatis-3/zh/index.html 对于语言的学习而言,马上上手去编程,多多练习 ...

  5. java持久层用文件_Java持久层框架MyBatis简单实例

    MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis .本文 ...

  6. java持久层框架mybatis如何防止sql注入

    2019独角兽企业重金招聘Python工程师标准>>> sql注入大家都不陌生,是一种常见的攻击方式,攻击者在界面的表单信息或url上输入一些奇怪的sql片段,例如"or ...

  7. Java数据库持久层框架基础:jdbc原理和使用综述

    Java数据库持久层框架基础:jdbc原理和使用综述 前言 jdbc基础架构 jbdc的使用 jdbc的主要接口 驱动 连接 连接池 会话Statement 结果集ResultSet 前言 目前jav ...

  8. mybatis generator 中文注释_[SpringBoot2.X] 23- 整合持久层技术 -MyBatis - 配置

    整合MyBatis 1搭建项目环境 1.1.1创建项目--略 11.2修改POM文件,添加相关依赖 <dependency><groupId>org.springframewo ...

  9. 优秀的持久层框架-Mybatis(上)

    文章目录 前言 一.MyBatis概述 1.1传统JDBC编程 1.2 mybatis的历史 1.3 mybatis是什么? 1.4如何使用? 1.5Mybatis架构 二. MyBatis环境搭建 ...

最新文章

  1. 网络管理经验谈:初级网管的网络安全
  2. MySQL 调优/优化的 101 个建议
  3. JZOJ 1219. Num
  4. web 小程序 ch3 小程序框架
  5. linux ftp中文乱码方块,Ubuntu下NetBeans中文乱码及方框问题的解决方法
  6. Oracle学习系列1-7
  7. 【转】并查集MST题集
  8. 初三学生什么时候上一对一效果最好?
  9. day 21 模块 和 包
  10. 评委打分表模板_杭州爸爸自制《奖惩表》火遍网络:请好好爱那个写作业的小孩...
  11. Atitit.java图片图像处理attilax总结
  12. Windows XP 优化
  13. Spring拦截器和过滤器的区别及详解
  14. 下载安装MinGW-w64详细步骤(c/c++的编译器gcc的windows版,win10真实可用)
  15. 海马扫描Linux,海马扫描公式识别软件
  16. 基于 Vue 技术栈的微前端方案实践
  17. 两套系统同个服务器,同一服务器运行两套workerman程序有什么需要特别修改的吗...
  18. 基于springboot的高校疫情打卡上报系统设计与实现 文档+项目源码及数据库文件+演示视频
  19. Dev中GridView——背景颜色改变
  20. python 字符串删除首尾空格

热门文章

  1. html新闻网页包括主页面,工作报告之html网页制作实验报告(8页)-原创力文档...
  2. 数据结构中关键路径算法的实现与应用
  3. echarts关系图节点点击事件
  4. eNSPV100 软件(华为ENSP模拟器)及其安装指南
  5. 任务管理器已被管理员禁用
  6. vue项目集成乾坤(qiankun)微前端
  7. Python 中的 urlencode 和 urldecode 操作
  8. Linux批量结束进程命令
  9. BugKu MISC 部分题目Write_up(三)
  10. 2021-2025年中国骨髓穿刺针行业市场供需与战略研究报告