一:方式
1业务装配:
2使用AutoMapping特性,在实现两表联合查询时通过别名完成映射
3 使用Mybatis的<resultMap>标签实现
二:resultMap标签
1 resultMap属性写在Mapper.xml中,由程序员控制查询结果和实体类的映射关系,默认mybatis使用AutoMapping特性。
2 使用<resultMap>标签时,<select>标签不写resultType属性,而是用resultMap属性引用<resultMap>标签,需要自己制定列名和属性名的对应,即使名不同也能对应,autoMapping通过表中列名和属性名相同从而自动对应
mapper.xml中:
三:resultmap实现关联单个对象(N+1方式)
1 N+1:先查询出某个表的全部信息,根据这个表的信息查询出另一个表的信息
2 与业务装配的区别:service里面写的代码,由mybatis完成
3 实现步骤:1 student类中包含一个Teacher对象 2 TeacherMapper中提供一个查询 3在StudentMapper中用association关联
4 在studentMapper中:1association装配一个对象时使用 2property:对象在类中的属性名 3select:通过哪个查询查出这个对象的信息 4column:把当前表的哪个列的值作为参数传递给另一个查询 5大前提使用N+1方式,如果列名和属性名相同,可以不配置,使用AutoMapping特性,但是MyBatis默认只会给列装配一次,column指定的列名必须在property中配置
TeacherMapper.xml:
关联一个对象,用association:
StudentMapper.xml:
Test.java测试:
运行后的查询结果中包含Teacher信息。
四:多表resultmap加载集合对象N+1方式
查询关联集合对象
一个Teacher可以包含多个student,所以一个tid可以对应多个student,但只能对应一个Teacher
Teacher.java:
studentMapper.xml:
TeacherMapper.xml:
collection标签标示属性是集合类型
test.java测试: