MyBatis 入门开发 ----Mapper接口开发

来源:互联网 发布:电子书排版编辑软件 编辑:程序博客网 时间:2024/06/05 12:59

MyBatis 入门开发 —-Mapper接口开发

                        ONE Goal , ONE Passion !

Mapper接口开发需要遵循以下规范:

  1. Mapper.xml文件中的namespace与mapper接口的类路径相同。
  2. Mapper接口方法名和Mapper.xml中定义的每个statement的id相同
  3. Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql 的parameterType的类型相同
  4. Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同

第一步: 编写映射文件

UserMapper.xml

    <?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 文件.

    /**     * 用户管理mapper     */    Public interface UserMapper {        //方法名符合第二条规范, 参数符合第三条规范,返回值类型符合第四条规范        public User findUserById(int id) throws Exception;    }

第三步: 加载配置文件

<mappers>        <mapper resource="UserMapper.xml"/> // resource根目录    </mappers>

第四步: 测试

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

原创粉丝点击