文档章节

mybatis中使用in查询时的注意事项

Carl_
 Carl_
发布于 2015/08/19 12:45
字数 314
阅读 3287
收藏 2
1. 当查询的参数只有一个时

  findByIds(List<Long> ids)

 1.a 如果参数的类型是List, 则在使用时,collection属性要必须指定为 list

复制代码

 <select id="findByIdsMap" resultMap="BaseResultMap">
         Select         <include refid="Base_Column_List" />         from jria where ID in
                  <foreach item="item" index="index" collection="list" 
                         open="(" separator="," close=")">
                        #{item}                </foreach>
  </select>

复制代码


 findByIds(Long[] ids)

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

复制代码

  <select id="findByIdsMap" resultMap="BaseResultMap">                 select
                 <include refid="Base_Column_List" />          from jria where ID in
                  <foreach item="item" index="index" collection="array" 
                         open="(" separator="," close=")">
                        #{item}                </foreach>
  </select>

复制代码


2. 当查询的参数有多个时,例如 findByIds(String name, Long[] ids)

 这种情况需要特别注意,在传参数时,一定要改用Map方式, 这样在collection属性可以指定名称

         下面是一个示例

复制代码

         Map<String, Object> params = new HashMap<String, Object>(2);        params.put("name", name);         params.put("ids", ids);
        mapper.findByIdsMap(params); 
 <select id="findByIdsMap" resultMap="BaseResultMap">                 select
                 <include refid="Base_Column_List" />          from jria where ID in
                  <foreach item="item" index="index" collection="ids" 
                         open="(" separator="," close=")">
                        #{item}                </foreach>
   </select>

复制代码

 

完整的示例如下:

例如有一个查询功能,Mapper接口文件定义如下方法:

List<Jria> findByIds(Long... ids);

使用 in 查询的sql拼装方法如下:

复制代码

 <select id="findbyIds" resultMap="BaseResultMap">                 select
                 <include refid="Base_Column_List" />          from jria where ID in
                  <foreach item="item" index="index" collection="array" 
                         open="(" separator="," close=")">
                        #{item}                </foreach>
  </select>

复制代码


本文转载自:http://www.cnblogs.com/xusir/archive/2013/07/24/3210286.html

共有 人打赏支持
Carl_
粉丝 40
博文 387
码字总数 12168
作品 0
广州
Mybatis实现union all 查询合并多个结果集

以下是mybatis mapper对应的sql语句: 注意事项: 使用union all 查询时,所有查询语句的返回结果字段名称和个数必须一致。

boonya
2016/06/13
4.4K
1
《深入理解mybatis原理》 MyBatis的一级缓存实现详解 及使用注意事项

MyBatis是一个简单,小巧但功能非常强大的ORM开源框架,它的功能强大也体现在它的缓存机制上。MyBatis提供了一级缓存、二级缓存 这两个缓存机制,能够很好地处理和维护缓存,以提高系统的性能...

java梦想家01
2016/01/11
527
1
Spring Boot + Mybatis + Redis as L2cache

1.背景 Spring-Boot因其提供了各种开箱即用的插件,使得它成为了当今最为主流的Java Web开发框架之一。Mybatis是一个十分轻量好用的ORM框架。Redis是当今十分主流的分布式key-value型数据库,...

梨加橙
2017/08/08
0
0
MyBatis 3.2.0 发布,Java 数据库持久层框架

MyBatis团队于2013年2月21日正式发布 MyBatis 3.2.0 新特性包括: 支持可扩展脚本引擎 支持可扩展字节码提供器和Java辅助类 缓存嵌套查询 改善日志 修正了40余处BUG 更新注意事项: MyBatis 3...

t莫名
2013/02/27
6.1K
47
Mybatis 通用 Mapper 3.0.0 发布

MyBatis通用Mapper3 极其方便的使用Mybatis单表的各种通用方法 Mapper 3.0.0更新日志: 将EntityMapper和SqlMapper移出,现在是独立项目EntityMapper 将Mapper全部接口方法拆分为独立接口,方...

Liuzh_533
2015/06/05
5.7K
8

没有更多内容

加载失败,请刷新页面

加载更多

利用碎片化时间Get Linux系统

起初,我做着一份与IT毫无关系的工作,每月领着可怜的工资,一直想改变现状,但无从下手,也就是大家熟知的迷茫。我相信,每一个人都会或多或少的经历过迷茫,迷茫每一个选择,迷茫工作或者生...

Linux就该这么学
17分钟前
0
0
图像显示深入学习一:Activity启动过程

一个月左右写了图像显示深入学习之文章开篇文章表明了自己近期的计划,前半年重新学习了opengl es,c++以及Linux的一些知识,觉得是时候开始看图像这一块的源码了,边看边补缺补漏吧。 作为该...

JerryLin123
39分钟前
1
0
给MySQL授权远程访问

putty登录服务器; 登录MySQL: mysql -u root -p 新建远程用户: CREATE USER 'myusername' IDENTIFIED BY 'mypassword'; 授权: grant all on *.* to john@'101.102.103.104' identified by......

sweethome
今天
1
0
在t-io老巢造谣,不过有造谣的就会有反造谣的!

只发当事人的截图,不发表评论,以免有引导嫌疑 PS: 截图是由不同的人发过来的 本人已经不在此微信群 图3:有造谣的,就有反造谣的 图4是2018-09-23的t-io官方群的一个发言小统计,有助于让...

talent-tan
今天
99
0
heartbeat 资源

drbd+apache+heartbeat : http://blog.51cto.com/11838039/1827901 heartbeat双机热备的架设 : http://blog.51cto.com/11838039/1827560 对heaetbeat的深一步认识 : http://blog.51cto.co......

寰宇01
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部