浅谈resultMap的用法及关联结果集映射

2025-05-29 0 48

resultType

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

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

resultMap

resultMap可以实现将查询结果映射为复杂类型的pojo,比如在查询结果映射对象中包括pojo和list实现一对一查询和一对多查询。

浅谈resultMap的用法及关联结果集映射

先在Mapper文件中,配置基本的sql语句

  1. <!– 查询所有的订单数据 –>
  2. <!– resultMap:填入配置的resultMap标签的id值 –>
  3. <select id="queryOrderAll" resultMap="orderResultMap">
  4. SELECT id, user_id,
  5. number,
  6. createtime, note FROM `order`
  7. </select>

配置resultMap标签,映射不同的字段和属性名

  1. <!– resultMap最终还是要将结果映射到pojo上,type就是指定映射到哪一个pojo –>
  2. <!– id:设置ResultMap的id –>
  3. <resultMap type="order" id="orderResultMap">
  4. <!– 定义主键 ,非常重要。如果是多个字段,则定义多个id –>
  5. <!– property:主键在pojo中的属性名 –>
  6. <!– column:主键在数据库中的列名 –>
  7. <id property="id" column="id" />
  8. <!– 定义普通属性 –>
  9. <result property="userId" column="user_id" />
  10. <result property="number" column="number" />
  11. <result property="createtime" column="createtime" />
  12. <result property="note" column="note" />
  13. </resultMap>

结果就可以封装到pojo类型中

使用resultMap进行关联查询

一对一查询

一对一数据模型:订单用户

一个订单信息只会是一个人下的订单,所以从查询订单信息出发关联查询用户信息为一对一查询。如果从用户信息出发查询用户下的订单信息则为一对多查询,因为一个用户可以下多个订单。

浅谈resultMap的用法及关联结果集映射

改造pojo类

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

浅谈resultMap的用法及关联结果集映射

配置Mapper.xml配置文件

OrderMapper.xml

先使用id和result属性,映射order类的结果集,然后在使用association映射关联对象User的结果集

  1. <resultMap type="order" id="orderUserResultMap">
  2. <id property="id" column="id" />
  3. <result property="userId" column="user_id" />
  4. <result property="number" column="number" />
  5. <result property="createtime" column="createtime" />
  6. <result property="note" column="note" />
  7. <!– association :配置一对一属性 –>
  8. <!– property:order里面的User属性名 –>
  9. <!– javaType:属性类型 –>
  10. <association property="user" javaType="user">
  11. <!– id:声明主键,表示user_id是关联查询对象的唯一标识–>
  12. <id property="id" column="user_id" />
  13. <result property="username" column="username" />
  14. <result property="address" column="address" />
  15. </association>
  16. </resultMap>
  17. <!– 一对一关联,查询订单,订单内部包含用户属性 –>
  18. <select id="queryOrderUserResultMap" resultMap="orderUserResultMap">
  19. SELECT
  20. o.id,
  21. o.user_id,
  22. o.number,
  23. o.createtime,
  24. o.note,
  25. u.username,
  26. u.address
  27. FROM
  28. `order` o
  29. LEFT JOIN `user` u ON o.user_id = u.id
  30. </select>

测试

  1. @Test
  2. public void testQueryOrderUserResultMap() {
  3. // mybatis和spring整合,整合之后,交给spring管理
  4. SqlSession sqlSession = this.sqlSessionFactory.openSession();
  5. // 创建Mapper接口的动态代理对象,整合之后,交给spring管理
  6. UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
  7. // 使用userMapper执行根据条件查询用户,结果封装到Order类中
  8. List<Order> list = userMapper.queryOrderUserResultMap();
  9. for (Order o : list) {
  10. System.out.println(o);
  11. }
  12. // mybatis和spring整合,整合之后,交给spring管理
  13. sqlSession.close();
  14. }

结果

浅谈resultMap的用法及关联结果集映射

一对多查询

查询所有用户信息及相关订单。

修改pojo类,在pojo类添加订单集合属性

浅谈resultMap的用法及关联结果集映射

修改UserMapper.xml配置文件

先使用id和result配置映射User类的结果,然后使用一对多关系的collection标签配置Order结果

  1. <resultMap type="user" id="userOrderResultMap">
  2. <id property="id" column="id" />
  3. <result property="username" column="username" />
  4. <result property="birthday" column="birthday" />
  5. <result property="sex" column="sex" />
  6. <result property="address" column="address" />
  7. <!– 配置一对多的关系
  8. property:填写pojo类中集合类类属性的名称
  9. javaType:填写集合类型的名称
  10. –>
  11. <collection property="orders" javaType="list" ofType="order">
  12. <!– 配置主键,是关联Order的唯一标识 –>
  13. <id property="id" column="oid" />
  14. <result property="number" column="number" />
  15. <result property="createtime" column="createtime" />
  16. <result property="note" column="note" />
  17. </collection>
  18. </resultMap>
  19. <!– 一对多关联,查询订单同时查询该用户下的订单 –>
  20. <select id="queryUserOrder" resultMap="userOrderResultMap">
  21. SELECT
  22. u.id,
  23. u.username,
  24. u.birthday,
  25. u.sex,
  26. u.address,
  27. o.id oid,
  28. o.number,
  29. o.createtime,
  30. o.note
  31. FROM
  32. `user` u
  33. LEFT JOIN `order` o ON u.id = o.user_id
  34. </select>

测试结果

浅谈resultMap的用法及关联结果集映射

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

原文链接:https://blog.csdn.net/qq_42780864/article/details/81429114

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 浅谈resultMap的用法及关联结果集映射 https://www.kuaiidc.com/105513.html

相关文章

发表评论
暂无评论