属性
子节点
子节点属性
说明:子节点 id 和 result 均可实现最基本的结果集映射,将列映射到简单数据类型的属性。这两者唯一不同的是:在比较对象实例时 id 将作为结果集的标识属性。这有助于提高总体性能,特别是应用缓存和嵌套结果映射的时候。而若要实现高级结果映射,就需要学习下面两个配置项: association 和 collection。
代码如下:
<resultMap id="userMap" type="com.atguigu.domain.User">
<id column="id" property="id">id>
<result column="birthday" property="birthday">result>
<result column="sex" property="sex">result>
<result column="address" property="address">result>
<result column="username" property="username">result>
resultMap>
association:映射到 JavaBean 的某个 “复杂类型” 属性,比如 JavaBean 类,即 JavaBean 内部嵌套一个复杂数据类型(JavaBean)属性,这种情况就属于复杂类型的关联。但是需要注意: association 仅处理一对一的关联关系。
ssociation 的属性
ssociation 的子元素
说明
(1)在做结果映射的过程中,需要注意:要确保所有的列名都是唯一且无歧义的。
(2)id 子元素在嵌套结果映射中扮演了非常重要的角色,应该指定一个或者多个属性来唯一标识这个结果集。实际上,即便没有指定 id, MyBatis 也会工作,但是会导致严重的性能开销,所以最好选择尽量少的属性来唯一标识结果,主键或者联合主键均可。
代码如下
private Role role; //复杂类型:用户角色
public List<User> getUserListByRoleId(@Param("uRole")int roleId);
<select id="getUserListByRoleId" resultMap="userRoleResult"
parameterType="int">
SELECT u.* , r.id AS r_id , r.`roleCode` , r.`roleName`
FROM `smbms_user` AS u,`smbms_role` AS r
WHERE u.`userRole`=#{uRole} AND u.`userRole`=r.`id`
select>
<resultMap type="user" id="userRoleResult">
<id property="id" column="id" />
<result property="userCode" column="userCode" />
<result property="userName" column="userName" />
<result property="userRole" column="userRole" />
<association property="role" javaType="role">
<id property="id" column="r_id" />
<result property="roleCode" column="roleCode" />
<result property="roleName" column="roleName" />
association>
resultMap>
复用 association 的结果映射
association 提供了的另一个属性: resultMap 通过这个属性可以扩展一个 resultMap 来进行联合映射,这样就可以使 role 结果映射重复使用。特别适合 association 的结果映射比较多的情况,当然,若不需要重用,也可按照上面代码的写法,直接嵌套这个联合结果映射,根据具体业务而定。
<select id="getUserListByRoleId" resultMap="userRoleResult"
parameterType="int">
SELECT u.* , r.id AS r_id , r.`roleCode` , r.`roleName`
FROM `smbms_user` AS u,`smbms_role` AS r
WHERE u.`userRole`=#{uRole} AND u.`userRole`=r.`id`
select>
<resultMap type="user" id="userRoleResult">
<id property="id" column="id" />
<result property="userCode" column="userCode" />
<result property="userName" column="userName" />
<result property="userRole" column="userRole" />
<association property="role" javaType="role" resultMap="roleResult" />
resultMap>
<resultMap type="role" id="roleResult">
<id property="id" column="r_id"/>
<result property="roleCode" column="roleCode"/>
<result property="roleName" column="roleName"/>
resultMap>
collection 元素的作用和 association 元素的作用差不多一样,事实上,它们非常类似,也是映射到 JavaBean 的某个 “复杂类型” 属性,只不过这个属性是一个集合列表,即 JavaBean 内部嵌套一个复杂数据类型(集合)属性。和使用 association 元素一样,我付使用嵌套查询,或者从连接中嵌套结果集。
collection 的属性
collection 的子元素
代码如下
private List<Address> addressList; //用户地址列表
public List<User> getAddressListByUserId(@Param("id")int userId);
<select id="getAddressListByUserId" resultMap="userAddressResult" parameterType="int">
SELECT u.*,a.`id` AS a_id ,a.`contact`,a.`addressDesc`,a.`postCode`,a.`tel`
FROM `smbms_user` u ,`smbms_address` a
WHERE u.`id`=a.`userId` AND u.`id`=#{id}
select>
<resultMap type="user" id="userAddressResult">
<id property="id" column="id"/>
<result property="userCode" column="userCode"/>
<result property="userName" column="userName"/>
<collection property="addressList" ofType="address">
<id property="id" column="a_id"/>
<result property="postCode" column="postCode"/>
<result property="tel" column="tel"/>
<result property="contact" column="contact"/>
<result property="addressDesc" column="addressDesc"/>
collection>
resultMap>
复用 collection 的结果映射
提取相应代码到一个 resultMap 中,给 collection 增加 resultMap 属性进行外部引用即可。
<select id="getAddressListByUserId" resultMap="userAddressResult" parameterType="int">
SELECT u.*,a.`id` AS a_id ,a.`contact`,a.`addressDesc`,a.`postCode`,a.`tel`
FROM `smbms_user` u ,`smbms_address` a
WHERE u.`id`=a.`userId` AND u.`id`=#{id}
select>
<resultMap type="user" id="userAddressResult">
<id property="id" column="id"/>
<result property="userCode" column="userCode"/>
<result property="userName" column="userName"/>
<collection property="addressList" ofType="address" resultMap="addressResult"/>
resultMap>
<resultMap type="address" id="addressResult">
<id property="id" column="a_id"/>
<result property="postCode" column="postCode"/>
<result property="tel" column="tel"/>
<result property="contact" column="contact"/>
<result property="addressDesc" column="addressDesc"/>
resultMap>