背景
通常我们查找的时候可能会有多个条件,并且是批量查询的时候,我们可以使用多条件IN语句,如我们已经获取了一部分的数据,想根据这些数据,从数据库查出这些数据的全部字段时,就可以使用多条件IN
场景
假设我们现在已经有了一个
List<User>
但是只有User的部分字段,如
id和username
,现在想要对比数据库把
id和username
对应的实体字段全部查出来的时候就可以使用这个方式,但要注意这里的
id和username
最好是
联合索引
,能唯一表示一条记录
select * from user
where (id, username...) in ((001, 'tom',...),(002, 'bob',...),...)
应用
我们一般会结合MyBatis进行多字段批量IN查询,主要是业务理清就行
<select id='selectUserByIdAndUsername' parameterType = 'list'>
select * from user
where (id, username) in
<foreach collections='list' item='item' open='(' close=')' seperator=','>
(#{item.id}, #{item.username})
</foreach>
</select>
总结
1.对于
联合索引的批量查询
都可以用批量的多条件IN语句
2.只要这个联合索引中
至少有一个主键或者唯一索引
就可以了
版权声明:本文为weixin_41405524原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。