问题:在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