我想重新使用来自不同* Mapper.xml文件的特定文件,这些文件都以某种方式读取相同的对象。
我有一个名为Project的数据库表,我为其创建了以下resultMap:
<resultMap id="ProjectMap" type="com.model.Project">
<id column="id" jdbcType="BIGINT" property="id" />
<result column="name" jdbcType="VARCHAR" property="name" />
<result column="client_prj_no" jdbcType="VARCHAR" property="clientPrjNo" />
<result column="notes" jdbcType="VARCHAR" property="notes" />
<result column="start_date" jdbcType="TIMESTAMP" property="startDate" />
...
<resultMap>
它在ProjectMapper.xml中运行良好,但是,现在我想创建一个ClientWithProjectsMapper.xml,我想要SELECT * FROM CLIENT,PROJECT,其中PROJECT.CLIENT_ID = CLIENT.ID并且客户端对象返回一个List对象。换句话说,我想用一个SQL获取ClientWithProjects。
在我的映射中,我想重用我在ProjectMapper.xml中定义的ProjectMap(没有复制/粘贴),但我不知道如何实现这一点。
我可以将ProjectMap分解为一个单独的文件,但我没有在MyBatis中找到#include其他文件的任何工具。
关于如何做到这一点的任何想法? (我正在使用Maven,是否有任何插件可以过滤寻找#include等文件,并将文件内容直接包含在正在处理的文件中?)。
感谢。
-AP_
答案 0 :(得分:25)
在mybatis-config.xml文件中导入所有mapper xmls后,您可以使用resultMap id和名称空间引用任何mapper xmls中配置的ResultMaps。
代表: ProjectMapper.xml
<mapper namespace="com.mybatisapp.mappers.ProjectMapper">
<resultMap id="ProjectMap" type="com.model.Project">
<id column="id" jdbcType="BIGINT" property="id" />
<result column="name" jdbcType="VARCHAR" property="name" />
<resultMap>
</mapper>
在ClientWithProjectsMapper.xml
中 <select id="selectProjectsByClient" parameterType="int"
resultMap="com.mybatisapp.mappers.ProjectMapper.ProjectMap">
select * from blahblah
</select>
在这里,您可以使用完全限定名称在“com.mybatisapp.mappers.ProjectMapper.ProjectMap”中
在另一个Mapper xml文件中引用resultMap