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