我们公司目前的开发是代码生成的Mapper 是不能动的,要写自己的Mapper只能基于原Mapper定义extMapper, 有时候我们想用原来的Mapper 的resultMap的话怎么办呢?很简单,直接用Mapper.resultMapId 就行,下面给出简单的例子,是一个Mapper引用另外一个Mapper的resultMap的 sql
主Mapper TblFasfdfssaveInfoMapper.xml:
<?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.su.dao.TblFasfdfssaveInfoMapper" >
<resultMap id="BaseResultMap" type="com.su.vo.TblFasfdfssaveInfo" >
<id column="id" property="id" jdbcType="INTEGER" />
<result column="savePath" property="savePath" jdbcType="VARCHAR" />
</resultMap>
<sql id="Base_Column_List" >
id, /*savePath,*/ url, cTime, /*uTime,*/ cUser, uUser, fileName
</sql>
</mapper>
外部Mapper TblFasfdfssaveInfoExtMapper ,引用 TblFasfdfssaveInfoMapper.xml 的resultMap和sql片段:
<?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.su.dao.TblFasfdfssaveInfoExtMapper" >
<select id="selectBySavePath" resultMap="com.su.dao.TblFasfdfssaveInfoMapper.BaseResultMap">/*此处引用了com.su.dao.TblFasfdfssaveInfoMapper的 BaseResultMap*/
SELECT
<include refid="com.su.dao.TblFasfdfssaveInfoMapper.Base_Column_List" />/*此处引用了com.su.dao.TblFasfdfssaveInfoMapper 中ID 为 Base_Column_List 的字段 */
FROM tblfasfdfssaveinfo WHERE savePath = #{savePath}
</select>
</mapper>
由此可见,Mapper 的sql字段和resultMap等是可以互相引用的, 但是最好是两个Mapper其实是操作一张表,这样在业务上来区分,避免业务上的混乱以及便于理解