mybatis collection的嵌套查询问题

iails 2018-05-29 05:34:46
三张表:

create table stu(
sno int auto_increment primary key ,
sname varchar(10)
);
create table class (
cid int auto_increment primary key,
cname varchar(10)
);
create table cs (
cid int,
sno int,
foreign key(cid) references class(cid),
foreign key(sno) references stu(sno)

);

数据:

insert into stu values (0,'stu1');
insert into stu values (0,'stu2');
insert into stu values (0,'stu3');
insert into stu values (0,'stu4');
insert into stu values (0,'stu5');

insert into class values (0,'class1');
insert into class values (0,'class2');

insert into cs values (1,1);
insert into cs values (1,2);
insert into cs values (2,3);
insert into cs values (2,4);
insert into cs values (2,5);

每个班级有多个学生

mapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.iails.site.dao.ClazzMapper">

<!-- 第一种方式 -->
<resultMap id="getList2ResultMap" type="com.iails.site.entity.Clazz">
<id property="classId" column="cid"/>
<result property="className" column="cname"/>
<collection property="students" column="cid" ofType="com.iails.site.entity.Student"
select="getList2Student">
<id property="studentId" column="sno"/>
<result property="studentName" column="sname"/>
</collection>
</resultMap>

<select id="getList2Student" resultType="com.iails.site.entity.Student">
select *
from stu,cs
where stu.sno=cs.sno and #{cid}=cs.cid
</select>
<select id="getList2" resultMap="getList2ResultMap">
select *
from class
</select>


<!-- 第二种方式 -->
<resultMap id="getListResultMap" type="com.iails.site.entity.Clazz">
<id property="classId" column="cid"/>
<result property="className" column="cname"/>
<collection property="students" column="cid" ofType="com.iails.site.entity.Student">
<id property="studentId" column="sno"/>
<result property="studentName" column="sname"/>
</collection>
</resultMap>

<select id="getList" resultMap="getListResultMap">
select *
from stu, class, cs
where class.cid=cs.cid and stu.sno=cs.sno
</select>
</mapper>


问题是:第二种方式没问题,第一种方法查询出来Class对象的Students列表有值,数目也符合,但是值为null

[{"classId":1,"className":"class1","students":[null, null]}, {"classId":2,"className":"class2","students":[null, null, null]}]

并且如果Student的属性名和stu的字段名完全一致或者把ofType和getList2Student的resultType改为"map"又可以映射成功。
是需要配置什么吗?
...全文
372 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
iails 2018-05-29
  • 打赏
  • 举报
回复
之前为何没找到那篇博文
iails 2018-05-29
  • 打赏
  • 举报
回复
发现提问下有一个链接https://blog.csdn.net/minpann/article/details/51217106,按照他的方法 把第一种方法改为这样就行了。。

    <!-- 第三种方式 -->
    <resultMap id="getList3ResultMap" type="com.iails.site.entity.Clazz">
        <id property="classId" column="cid"/>
        <result property="className" column="cname"/>
        <collection property="students" column="cid" ofType="com.iails.site.entity.Student"
                    select="getList3Student">

        </collection>
    </resultMap>

    <resultMap id="getList3StudentResultMap" type="com.iails.site.entity.Student">
        <id property="studentId" column="sno"/>
        <result property="studentName" column="sname"/>
    </resultMap>

    <select id="getList3Student" resultMap="getList3StudentResultMap">
        select *
        from stu,cs
        where stu.sno=cs.sno and #{cid}=cs.cid
    </select>
    <select id="getList3" resultMap="getList3ResultMap">
        select *
        from class
    </select>

81,094

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧