Mybatis的mapper注册
既然 MyBatis 的行为已经由上述元素配置完了,我们现在就要定义 SQL 映射语句了。但是首先我们需要告诉 MyBatis 到哪里去找到这些语句。 Java 在自动查找这方面没有提供一个很好的方法,所以最佳的方式是告诉 MyBatis 到哪里去找映射文件。你可以使用相对于类路径的资源引用, 或完全限定资源定位符(包括 file:/// 的 URL),或类名和包名等。例如:
<!-- Using classpath relative resources -->
<mappers>
<mapper resource="org/mybatis/builder/AuthorMapper.xml"/>
<mapper resource="org/mybatis/builder/BlogMapper.xml"/>
<mapper resource="org/mybatis/builder/PostMapper.xml"/>
</mappers>
<!-- Using url fully qualified paths -->
<mappers>
<mapper url="file:///var/mappers/AuthorMapper.xml"/>
<mapper url="file:///var/mappers/BlogMapper.xml"/>
<mapper url="file:///var/mappers/PostMapper.xml"/>
</mappers>
<!-- Using mapper interface classes -->
<mappers>
<mapper class="org.mybatis.builder.AuthorMapper"/>
<mapper class="org.mybatis.builder.BlogMapper"/>
<mapper class="org.mybatis.builder.PostMapper"/>
</mappers>
<!-- Register all interfaces in a package as mappers -->
<mappers>
<package name="org.mybatis.builder"/>
</mappers>
上述方式1和2是XML定义,3和4则是注解定义
XML定义是常用的方式,用法如下:
<select id="testMyBatisWorks" resultType="java.util.HashMap">
<![CDATA[
{call pQueryAsyncNoticeList (
#{0,mode=IN,jdbcType=INTEGER}
)
}
]]>
</select>
注解则是:
/**
* 【proc列表】用存储过程查询得到列表
* @param asyncStatus
* @return
*/
@Select("exec pQueryAsyncNoticeList #{asyncStatus}")
@Options(statementType=StatementType.CALLABLE)
List<Map<String, Object>> getList2(int asyncStatus);
Type interface XXXMapper is not known to the MapperRegistry.的解决办法。