mybatis 中使用collection注意事项

在使用mybatis中的collection的时候遇到了不少问题,下面记录一下:java

resultMap配置以下:mybatis

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.benben.dao.ModuleDao">
 <resultMap id="BaseResultMap" type="Module" >
  <id column="module_id" property="id" />
  <result column="module_name" property="name" />
  <collection property="authUsers" ofType="Auth"  resultMap="AuthUserMap"/>
  
 </resultMap>
 <resultMap id="AuthUserMap" type="Auth">
  <id column="auth_id" property="id"/>
  <result column="username" property="userName"/>
  <result column="password" property="password"/>
 </resultMap>app

 <select id="selectModule" resultMap="BaseResultMap">
 select mo.id module_id ,mo.name module_name,au.id auth_id ,au.username username,au.password password from td_module mo left outer join td_auth au on au.module_id=mo.id
 </select>
</mapper>spa

一、别名的使用,如xml

select mo.id module_id ,mo.name module_name,au.id auth_id ,au.username username,au.password password from td_module mo left outer join td_auth au on au.module_id=mo.idget

这里千万要记住命名成别名,若是不用的话,可能两个表的字段名称一致,形成了匹配错误,如两张表中都叫id,就会形成匹配错误io

二、ofType,这里是javabeen类module