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方法。