MySQL批量多条件的IN查询

  • Post author:
  • Post category:mysql




背景

通常我们查找的时候可能会有多个条件,并且是批量查询的时候,我们可以使用多条件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 版权协议,转载请附上原文出处链接和本声明。