Mybatis延迟加载和一级缓存之间的问题

本文探讨了Mybatis中延迟加载可能导致的循环问题及解决方案。当使用延迟加载查询学生对象并访问其成绩集时,由于一级缓存的存在,可能会导致查询异常。通过在查询学生语句上设置flushCache='true',可避免因缓存导致的问题。另外,当Spring管理事务时,将@Transactional注解放在service层会导致延迟加载异常,而放在dao层则不会,原因是不同事务层级下SqlSession的关闭时机不同,影响了延迟加载行为。
摘要由CSDN通过智能技术生成

问题:在mybatis里面,我们可以使用延迟加载来提高性能,同时减少代码量(只用写查询延时属性的statement语句的id可以),但是这有可能造成循环。比如学生(对应实体类Student)和成绩(对应实体类Score),一个学生有多个成绩,那么在学生实体类Student里面有一个scoreSet的集合,然后在成绩实体类Score里面有一个学生对象Student。

学生类:
public class Student {
	//省略了其他属性和方法
    private String id;
    private String name;
    private Set<Score> scoreSet=new HashSet<Score>();
	}
成绩类:
public class Score {
	//省略了其他属性和方法
     private Integer id;//id,唯一标识
     private Float score1;//一考成绩
     private Student student;//学生类
}

然后在StudentMapper.xml里面写一个StudentResultMap

<resultMap type="com.zxs666.model.Student" id="studentResultMap">
		<id column="id" property="id"/>
		<result column="name" property="name"/>
		<!-- 延迟加载scoreSet  这个select属性就是延迟该学生对应的s
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值