MyBatis中的多字段IN查询方式
更新时间:2025年10月20日 08:51:08 作者:demonic_yang
本文介绍了在MyBatis中进行多字段IN查询的目标SQL、Mapper接口定义及XML配置方法,并简要总结了相关个人经验,供读者参考和学习
MyBatis多字段IN查询
目标SQL
select * from demo t where (t.id, t.name) in (('1001', '张三'), ('1002', '李四'));
Mapper接口定义
//mapper接口定义
List<Map<String, Object>> getResult(@Param("list") List<Map<String, String>> list);
调用持久化层
//组装数据
List<Map<String, String>> list = Lists.newArrayList();
Map<String, String> map1 = Maps.newHashMap();
map1.put("id", "1001");
map1.put("name", "张三");
list.add(map1);
Map<String, String> map2 = Maps.newHashMap();
map2.put("id", "1002");
map2.put("name", "李四");
list.add(map2);
//调用dao层
List<Map<String, Object>> result = mapper.getResult(list);
MyBatis XML
<select id="getResult" resultType="java.util.HashMap">
select * from demo t where (t.id, t.name) in
<foreach collection="list" item="item" open="(" close=")" separator=",">
(#{item.id},#{item.name})
</foreach>
</select>
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
java 将 list 字符串用逗号隔开拼接字符串的多种方法
这篇文章主要介绍了java 将 list 字符串用逗号隔开拼接字符串,本文给大家分享四种方法,每种方法通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-12-12
spring boot+vue实现JSAPI微信支付的完整步骤
JSAPI支付是用户在微信中打开商户的H5页面,商户在H5页面通过调用微信支付提供的JSAPI接口调起微信支付模块完成支付,下面这篇文章主要给大家介绍了关于spring boot+vue实现JSAPI微信支付的相关资料,需要的朋友可以参考下2022-05-05


最新评论