Mapper接口开发需要遵循以下规范:
Mapper.xml文件中的namespace与mapper接口的类路径相同。
Mapper接口方法名和Mapper.xml中定义的每个statement的id相同
Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql 的parameterType的类型相同
Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同
第一步: 编写映射文件
UserMapper.xml
[AppleScript] 纯文本查看 复制代码
<?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="cn.fy.domain.UserMapper">
<select id="findUserById" parameterType="int" resultType="cn.fy.domain.User">
SELECT id,username,birthday,sex,address FROM USER WHERE id = #{id}
</select>
</mapper>
第二步: 编写映射文件
UserMapper.java 文件.
[AppleScript] 纯文本查看 复制代码
/**
-
用户管理mapper
*/
Public interface UserMapper {
//方法名符合第二条规范, 参数符合第三条规范,返回值类型符合第四条规范
public User findUserById(int id) throws Exception;}
第三步: 加载配置文件
[AppleScript] 纯文本查看 复制代码
<mappers><mapper resource="UserMapper.xml"/> // resource根目录
</mappers>
第四步: 测试
[AppleScript] 纯文本查看 复制代码br/>@Test
public void Mapper() {
SqlSession session = MyBatisUtil.getSession();//获取mapper接口的代理对象 UserMapper userMapper = session.getMapper(UserMapper.class); try { userMapper.findUserById(1); } catch (Exception e) { e.printStackTrace(); }
}
注意:selectOne和selectList
动态代理对象调用sqlSession.selectOne()和sqlSession.selectList()是根据mapper接口方法的返回值决定,如果返回list则调用selectList方法,如果返回单个对象则调用selectOne方法。
转载于:https://blog.51cto.com/13517854/2048373