Mybatis处理List参数过程
更新时间:2026年05月30日 09:47:37 作者:张井天
本文详细介绍了Mybatis处理List参数的方法,通过实体类StudentInfo示例,展示了两种不同类型的List传参查询,涵盖从前期准备SQL到Mapper接口及XML配置的全过程
Mybatis处理List参数
前期准备
sql:
CREATE TABLE `tb_student` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) COLLATE utf8_bin NOT NULL,
`age` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=26 DEFAULT CHARSET=utf8 COLLATE=utf8_bin ROW_FORMAT=DYNAMIC;
INSERT INTO `work`.`tb_student` (`id`, `name`, `age`) VALUES ('25', ' Ben ', '23');
INSERT INTO `work`.`tb_student` (`id`, `name`, `age`) VALUES ('26', 'Jack', '24');
INSERT INTO `work`.`tb_student` (`id`, `name`, `age`) VALUES ('27', 'Tom', '24');
INSERT INTO `work`.`tb_student` (`id`, `name`, `age`) VALUES ('28', 'Jerry', '19');
INSERT INTO `work`.`tb_student` (`id`, `name`, `age`) VALUES ('29', 'Lilian', '18');实体类 StudentInfo:
public class StudentInfo {
private Integer id;
private String name;
private Integer age;
// 省略 get、set 方法
}
示例
通过 两种不同数据类型的List 不同查询:
StudentDao :
/**
* 通过年龄和名称查询结果
* @param ages
* @param name
* @return
*/
List<StudentInfo> getListByAgesAndName(@Param("ages") List<Integer> ages, @Param("name") String name);
/**
* 通过年龄【实体中获取】和名称查询结果
* @param studentInfos
* @param name
* @return
*/
List<StudentInfo> getListByStudentInfoAndName(@Param("studentInfos") List<StudentInfo> studentInfos, @Param("name") String name);
StudentMapper.xml
<!-- 通过年龄和名称查询结果 -->
<select id="getListByAgesAndName" resultType="com.morning.all.entity.StudentInfo">
select * from tb_student
where name like CONCAT('%',#{name},'%')
and age in
<foreach collection="ages" item="age" index="index" open="(" close=")" separator=",">
#{age}
</foreach>
</select>
<!-- 通过年龄【实体中获取】和名称查询结果 -->
<select id="getListByStudentInfoAndName" resultType="com.morning.all.entity.StudentInfo">
select * from tb_student
where name like CONCAT('%',#{name},'%')
and age in
<foreach collection="studentInfos" item="studentInfo" index="index" open="(" close=")" separator=",">
#{studentInfo.age}
</foreach>
</select>以上就是关于Mybatis List传参以及使用!
总结
这些仅为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
详解Java ReentrantLock可重入,可打断,锁超时的实现原理
前面讲解了ReentrantLock加锁和解锁的原理实现,但是没有阐述它的可重入、可打断以及超时获取锁失败的原理,本文就重点讲解这三种情况,需要的可以了解一下2022-10-10
详解Spring Boot + Mybatis 实现动态数据源
这篇文章主要介绍了Spring Boot + Mybatis 实现动态数据源,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-04-04
SpringBoot打包发布到linux上(centos 7)的步骤
这篇文章主要介绍了SpringBoot打包发布到linux上(centos 7)的步骤,帮助大家更好的理解和使用springboot框架,感兴趣的朋友可以了解下2020-12-12
详解spring cloud构建微服务架构的网关(API GateWay)
这篇文章主要介绍了详解spring cloud构建微服务架构的网关(API GateWay),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-01-01


最新评论