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] 纯文本查看 复制代码 @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方法。