比如:一个老师拥有多个学生!
对于老师而言,就是一对多的关系!
1.环境搭建,和 多对一 一样
实体类:
public class Student {
private int id;
private String name;
private int tid;
}
public class Teacher {
private int id;
private String name;
//一个老师拥有多个学生
private List<Student> students;
}
按照结果嵌套处理:
<!--按结果嵌套查询-->
<select id="getTeacher" resultMap="TeacherStudent">
select s.id sid,s.name sname,t.name tname,t.id tid
from student s,teacher t
where s.tid=t.id and t.id=#{tid}
</select>
<resultMap id="TeacherStudent" type="Teacher">
<result property="id" column="tid"/>
<result property="name" column="tname"/>
<!--复杂的属性,我们需要但对于处理 对象:association 集合:collection-->
<!--javaType="" 指定类型的属性
集合中的泛型信息,我们使用价格ofType获取(这里得到的student是一个集合)
-->
<collection property="students" ofType="Student">
<result property="id" column="sid"/>
<result property="name" column="sname"/>
<result property="tid" column="tid"/>
</collection>
</resultMap>
按照查询嵌套处理:
<select id="getTeacher2" resultMap="TeacherStudent2">
select * from mybaits.teacher where id = #{tid}
</select>
<resultMap id="TeacherStudent2" type="Teacher">
<!--result property="id" column="id"属性和字段名一致,可省略不写-->
<collection property="students" javaType="ArrayList" ofType="Student" select="getStudentByTeacherId" column="id"
/>
</resultMap>
<select id="getStudentByTeacherId" resultType="Student">
select * from mybaits.student where tid = #{tid}
</select>
小结:
1.关联:association 【多对一】
2.集合:collection 【一对多】
3.JavaType && ofType
JavaType : 用来指定实体类中的属性
ofType :用来指定映射到List集合或者集合中的pojo类型,泛型中的约束类型!
注意点:
- 保证SQL的可读性,尽量保证通俗易懂!
- 注意一对多和多对一中,属性名和字段的问题!
- 如果问题不好排查,可以使用日志,建议使用Log4j