当前位置:   article > 正文

MySQL批量多条件的IN查询_mysql多条件批量查询

mysql多条件批量查询

背景

通常我们查找的时候可能会有多个条件,并且是批量查询的时候,我们可以使用多条件IN语句,如我们已经获取了一部分的数据,想根据这些数据,从数据库查出这些数据的全部字段时,就可以使用多条件IN

场景

假设我们现在已经有了一个List<User>但是只有User的部分字段,如id和username,现在想要对比数据库把id和username对应的实体字段全部查出来的时候就可以使用这个方式,但要注意这里的id和username最好是联合索引,能唯一表示一条记录

select * from user
where (id, username...) in ((001, 'tom',...),(002, 'bob',...),...)
  • 1
  • 2

应用

我们一般会结合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
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

总结

1.对于联合索引的批量查询都可以用批量的多条件IN语句
2.只要这个联合索引至少有一个主键或者唯一索引就可以了

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/730145
推荐阅读
相关标签
  

闽ICP备14008679号