mybatis如何封装List<String>类型属性
数据库
有一个班级表
然后还有一个学生表
需要封装成的对象
/* *@author huanghaitao *@description *@Date 2022/1/27 */ @Data public class AClassAndStudent { private Integer classId; private String className; private List<String> stuNames; }
第一种写法
封装ResultMap写法
<resultMap id="AClassAndStudent" type="com.ruoyi.system.domain.AClassAndStudent"> <result column="class_id" property="classId"/> <result column="class_name" property="className"/> <collection property="stuNames" ofType="string"> <constructor> <arg column="stu_name"/> </constructor> </collection> </resultMap>
sql语句
<select id="testSelectSql" resultMap="AClassAndStudent"> select c.id class_id, c.name class_name, s.name stu_name from class c left join student s on c.id = s.class_id where c.id = 1 </select>
打印结果
AClassAndStudent(classId=1, className=3班, stuNames=[张三, 李四, 王二, 赵六])
第二种写法
<resultMap id="AClassAndStudent" type="com.ruoyi.system.domain.AClassAndStudent"> <result column="class_id" property="classId"/> <result column="class_name" property="className"/> <collection property="stuNames" column="class_id" ofType="string" select="selectStuName"/> </resultMap> <select id="testSelectSql" resultMap="AClassAndStudent"> select c.id class_id, c.name class_name from class c where c.id = 1 </select> <select id="selectStuName" resultType="java.lang.String"> select name stu_name from Student where class_id = 1 </select>
上面那个爆红 不用管的
sql语句打印 有点区别
但是结果是一样的
AClassAndStudent(classId=1, className=3班, stuNames=[张三, 李四, 王二, 赵六])
第三种写法
修改封装方式
新建一个学生类
/* *@author huanghaitao *@description *@Date 2022/1/27 */ @Data public class AStudent { private Integer id; private Integer classId; private String name; }
一个班级类,这个班级类包含学生类
import java.util.List; @Data public class AClassContainStudent { private Integer id; private String name; private List<AStudent> studentList; }
这样的话,ResultMap写法是下面这样的
<resultMap id="AClassContainStudent" type="com.ruoyi.system.domain.AClassContainStudent"> <id column="class_id" property="id"/> <result column="class_name" property="name"/> <collection property="studentList" resultMap="AStudent"/> </resultMap> <resultMap id="AStudent" type="com.ruoyi.system.domain.AStudent"> <id column="stu_id" property="id"/> <result column="class_id" property="classId"/> <result column="stu_name" property="name"/> </resultMap> <select id="testSelectSqlTwo" resultMap="AClassContainStudent"> select c.id class_id, c.name class_name, s.id stu_id, s.name stu_name from class c left join student s on c.id = s.class_id where c.id = 1 </select>
打印的结果
AClassContainStudent(id=1, name=3班, studentList=[AStudent(id=1,
classId=1, name=张三), AStudent(id=2, classId=1, name=李四),
AStudent(id=3, classId=1, name=王二), AStudent(id=4, classId=1,
name=赵六)])
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Redisson分布式闭锁RCountDownLatch的使用详细讲解
分布式锁和我们java基础中学习到的synchronized略有不同,synchronized中我们的锁是个对象,当前系统部署在不同的服务实例上,单纯使用synchronized或者lock已经无法满足对库存一致性的判断。本次主要讲解基于rediss实现的分布式锁2023-02-02JAVA序列化Serializable及Externalizable区别详解
这篇文章主要介绍了JAVA序列化Serializable及Externalizable区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2020-07-07使用IDEA搭建一个简单的SpringBoot项目超详细过程
这篇文章主要介绍了使用IDEA搭建一个简单的SpringBoot项目超详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-02-02
最新评论