[MyBatis]-15 多表关联查询 N+1方式


prtyaa
prtyaa 2023-12-27 16:21:23 65037
分类专栏: 资讯

这里演示的是多对一

多:学生

一:班级

多个学生一个班级,通过查询学生后再查询班级


所谓的N+1次查询呢,实际上就是mybatis帮我们做了业务装配来看下下面的图

执行一次学生的查询,有几个学生执行几次班级的查询

实际上就是在上一篇文章的StudentMapper.xml里面使用了resultMap来实现n+1查询

<mapper namespace="com.lin.mapper.StudentMapper">
<resultMap id="smap" type="Student">
    <id property="id" column="id"/>
    <result property="name" column="name"/>
    <result property="age" column="age"/>
    <result property="gender" column="gender"/>
    <result property="cid" column="cid"/>
    <!-- association 用于关联一个对象 -->
    <association property="clazz" select="com.lin.mapper.ClazzMapper.selById" column="cid"/>
</resultMap>
    <select id="selAll" resultMap="smap">
        select * from t_student;
    </select>
</mapper>

在resultMap标签里,我们使用了一个association的标签,这个标签就帮助了我们完成业务装配,

property表示关联的实体属性名

select 表示继续引用查询的命名空间+id

column表示查询时需要传递的列(值)。

 

注意:

当属性名与字段名相同时可以省略 √。但是要注意只能使用一次,如果要在结果集中显示该数值需要显示的绑定。所以可以简写为

<mapper namespace="com.lin.mapper.StudentMapper">
<resultMap id="smap" type="Student">
    <result property="cid" column="cid"/>
    <!-- association 用于关联一个对象 -->
    <association property="clazz" select="com.lin.mapper.ClazzMapper.selById" column="cid"/>
</resultMap>
    <select id="selAll" resultMap="smap">
        select * from t_student;
    </select>
</mapper>

其他基本与上篇文章保持不变,只是在serviceimp里面不再需要查询班级的mapper

public class StudentServiceImpl implements StudentService {
    @Override
    public List<Student> selAll() {
        SqlSession session = MyBatisUtil.getSession();
        //获取到学生mapper
        StudentMapper stuMapper = session.getMapper(StudentMapper.class);
        List<Student> list = stuMapper.selAll();
        session.close();
        return list;
    }
}

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=31579
赞同 0
评论 0 条
prtyaaL1
粉丝 1 发表 2554 + 关注 私信
上周热门
银河麒麟添加网络打印机时,出现“client-error-not-possible”错误提示  1487
银河麒麟打印带有图像的文档时出错  1405
银河麒麟添加打印机时,出现“server-error-internal-error”  1194
统信操作系统各版本介绍  1116
统信桌面专业版【如何查询系统安装时间】  1114
统信桌面专业版【全盘安装UOS系统】介绍  1068
麒麟系统也能完整体验微信啦!  1026
统信【启动盘制作工具】使用介绍  672
统信桌面专业版【一个U盘做多个系统启动盘】的方法  616
信刻全自动档案蓝光光盘检测一体机  526
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
信创开放社区邀请他人注册的具体步骤如下 15
如何玩转信创开放社区—从小白进阶到专家 15
方德桌面操作系统 14
我有15积分有什么用? 13
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

添加我为好友,拉您入交流群!

请使用微信扫一扫!