登录
首页 >  数据库 >  MySQL

resultMap的使用

来源:SegmentFault

时间:2023-01-26 10:46:50 379浏览 收藏

有志者,事竟成!如果你在学习数据库,那么本文《resultMap的使用》,就很适合你!文章讲解的知识点主要包括MySQL、Java、程序员,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

resultType可以把查询的结果封装在pojo中,但pojo类的属性名和查询到的数据库表的字段名一致。

如果sql查询到的字段与pojo的属性名不一致,则需要使用resultMap将字段名和属性名对应起来,进行手动配置封装,将结果映射到pojo中

<!-- resultMap最终还是要将结果映射到pojo上,type就是指定映射到哪一个pojo -->
    <!-- id:设置ResultMap的id -->
    <resultmap type="order" id="orderResultMap"><!-- 定义主键 ,非常重要。如果是多个字段,则定义多个id --><!-- property:主键在pojo中的属性名 --><!-- column:主键在数据库中的列名 --><id property="id" column="id"></id><!-- 定义普通属性 --><result property="userId" column="user_id"></result><result property="number" column="number"></result><result property="createtime" column="createtime"></result><result property="note" column="note"></result></resultmap>

resultMap中association一对一的关系
一对一数据模型:订单用户
一个订单信息只会是一个人下的订单,所以从查询订单信息出发关联查询用户信息为一对一查询。如果从用户信息出发查询用户下的订单信息则为一对多查询,因为一个用户可以下多个订单 。

改造pojo类
在订单类(order)中添加User属性,User属性是一个引用类型,用于存储关联查询的用户信息,因为关联关系是一对一,所以只需要添加单个属性即可

image.png

<resultmap type="order" id="orderUserResultMap"><id property="id" column="id"></id><result property="userId" column="user_id"></result><result property="number" column="number"></result><result property="createtime" column="createtime"></result><result property="note" column="note"></result><!-- association :配置一对一属性 --><!-- property:order里面的User属性名 --><!-- javaType:属性类型 --><association property="user" javatype="user"><!-- id:声明主键,表示user_id是关联查询对象的唯一标识--><id property="id" column="user_id"></id><result property="username" column="username"></result><result property="address" column="address"></result></association></resultmap><!-- 一对一关联,查询订单,订单内部包含用户属性 -->&lt;select id=&quot;queryOrderUserResultMap&quot; resultmap=&quot;orderUserResultMap&quot;&gt;
    SELECT  o.id, o.user_id, o.number, o.createtime,o.note,
    u.username,u.address
    FROM
    `order` o LEFT JOIN `user` u 
    ON o.user_id = u.id
&lt;/select&gt;

resultMap 中collection一对多和多对多关系
修改pojo类,在pojo类添加订单集合属性
一个用户对应这多个订单

image.png

<resultmap type="user" id="userOrderResultMap"><id property="id" column="id"></id><result property="username" column="username"></result><result property="birthday" column="birthday"></result><result property="sex" column="sex"></result><result property="address" column="address"></result><!-- 配置一对多的关系
        property:填写pojo类中集合类类属性的名称
        javaType:填写集合类型的名称 
    --><collection property="orders" javatype="list" oftype="order"><!-- 配置主键,是关联Order的唯一标识 --><id property="id" column="oid"></id><result property="number" column="number"></result><result property="createtime" column="createtime"></result><result property="note" column="note"></result></collection></resultmap><!-- 一对多关联,查询订单同时查询该用户下的订单 -->&lt;select id=&quot;queryUserOrder&quot; resultmap=&quot;userOrderResultMap&quot;&gt;
    SELECT u.id, u.username,u.birthday,u.sex,u.address,
    o.id oid, o.number, o.createtime,o.note
    FROM `user` u LEFT JOIN `order` o 
    ON u.id = o.user_id
&lt;/select&gt;

到这里,我们也就讲完了《resultMap的使用》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于mysql的知识点!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>