mybatis如何封装List<String>类型属性

 更新时间:2023年12月06日 09:47:45   作者:hhtSeeTheWorld  
这篇文章主要介绍了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的使用详细讲解

    Redisson分布式闭锁RCountDownLatch的使用详细讲解

    分布式锁和我们java基础中学习到的synchronized略有不同,synchronized中我们的锁是个对象,当前系统部署在不同的服务实例上,单纯使用synchronized或者lock已经无法满足对库存一致性的判断。本次主要讲解基于rediss实现的分布式锁
    2023-02-02
  • Java之Spring注解配置bean实例代码解析

    Java之Spring注解配置bean实例代码解析

    这篇文章主要介绍了Java之Spring注解配置bean实例代码解析,具有一定参考价值,文中还有有关Spring学习的资料下载链接及相关内容推荐,需要的朋友可以了解下。
    2017-09-09
  • JAVA序列化Serializable及Externalizable区别详解

    JAVA序列化Serializable及Externalizable区别详解

    这篇文章主要介绍了JAVA序列化Serializable及Externalizable区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-07-07
  • Java中的继承与接口解读

    Java中的继承与接口解读

    这篇文章主要介绍了Java中的继承与接口使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-02-02
  • Java中Maven的依赖管理问题小结

    Java中Maven的依赖管理问题小结

    这篇文章主要介绍了Java中Maven的依赖管理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-05-05
  • 为什么阿里巴巴要求日期格式化时必须有使用y表示年

    为什么阿里巴巴要求日期格式化时必须有使用y表示年

    这篇文章主要介绍了为什么阿里巴巴要求日期格式化时必须有使用y表示年,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • postman中POST请求时参数包含参数list设置方式

    postman中POST请求时参数包含参数list设置方式

    这篇文章主要介绍了postman中POST请求时参数包含参数list设置方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-05-05
  • java设计模式:建造者模式之生产线

    java设计模式:建造者模式之生产线

    这篇文章主要介绍了Java设计模式之建造者模式,结合具体实例形式分析了建造者模式的概念、原理、实现方法与相关使用注意事项,需要的朋友可以参考下
    2021-08-08
  • 使用IDEA搭建一个简单的SpringBoot项目超详细过程

    使用IDEA搭建一个简单的SpringBoot项目超详细过程

    这篇文章主要介绍了使用IDEA搭建一个简单的SpringBoot项目超详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • Spring自定义参数解析器代码实例

    Spring自定义参数解析器代码实例

    这篇文章主要介绍了Spring自定义参数解析器代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12

最新评论