mybatis的resultMap自定义结果映射规则

更多精彩文章欢迎关注公众号“Java之康庄大道”

dao接口

User myGetUserById(Integer id);

sql xml自定义封装规则

<!--自定义某个javabean的封装规则
type:自定义规则的java类型
id:唯一标识方便引用
-->
 <resultMap id="myUser" type="com.yunqing.mybatis.bean.User">
        <!--id指定主键列的封装规则,return指定普通列的封装规则
        column:数据库列名
        property:对应的javabean属性
        -->
        <id column="id" property="id"/>
        <result column="name" property="name"/>
        <result column="age" property="age"/>
    </resultMap>
    <!--使用自定义封装规则-->
    <select id="myGetUserById" resultMap="myUser">
        SELECT * FROM t_user WHERE id = #{id}
    </select>

test测试类

    @Test
    public void myGetUserById() throws IOException {
        String r = "mybatis-config.xml";
        InputStream is = Resources.getResourceAsStream(r);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
        User user = userMapper.myGetUserById(1);
        System.out.println(user);
    }

关于级联映射结果集的规则:

javabean的User.java

    private Integer id;
    private String name;
    private Integer age;
    private Department dep;//所属部门

Department.java

    private Integer id;//部门id
    private String departmentName;//部门名

通过用户id查询用户和部门信息

User getUserAndDepById(Integer id);

returnMap映射级联结果集

第一种:

<!-- 自定义结果集,使用级联属性封装第一种方式-->
    <resultMap id="myMapJiLian" type="com.yunqing.mybatis.bean.User">
        <id column="id" property="id"/>
        <result column="name" property="name"/>
        <result column="age" property="age"/>
        <result column="did" property="dep.id"/>
        <result column="dep_name" property="dep.departmentName"/>
    </resultMap>

<!--使用级联属性-->
    <select id="getUserAndDepById" resultMap="myMapJiLian">
        SELECT u.id id,u.name name,u.age age,u.dep_id dep_id,dep.id did,dep.department dep_name FROM t_user u,t_dep dep WHERE
        u.dep_id=dep.id AND u.id=#{id}
    </select>

第二种

<!-- 自定义结果集第二种方式
        association可以指定联合javabean对象
        property指定那个属性是联合的对象即外键
        javaType不能省略,指定这个属性对象的类型
    -->
    <resultMap id="myMapAss" type="com.yunqing.mybatis.bean.User">
        <id column="id" property="id"/>
        <result column="name" property="name"/>
        <result column="age" property="age"/>
        <association property="dep" javaType="com.yunqing.mybatis.bean.Department">
            <id column="did" property="id"/>
            <result column="dep_name" property="departmentName"/>
        </association>
    </resultMap>

<!--使用级联属性-->
    <select id="getUserAndDepById" resultMap="myMapAss">
        SELECT u.id id,u.name name,u.age age,u.dep_id dep_id,dep.id did,dep.department dep_name FROM t_user u,t_dep dep WHERE
        u.dep_id=dep.id AND u.id=#{id}
    </select>

 

posted @ 2017-12-25 21:03  云晴  阅读(13133)  评论(0编辑  收藏  举报