我是靠谱客的博主 甜美月光,这篇文章主要介绍mybatis查询子对象(一对一、一对多、互相嵌套查询等),现在分享给大家,希望可以做个参考。

Mybatis left join 一对一、一对多、多对多查询

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<!-- 一对一查询 ,一个订单对应一个用户--> <resultMap type="com.Orders" id="OrdersUserResultMap"> <id column="id" property="id"/> <result column="user_id" property="userid"/> <result column="number" property="number"/> <result column="createtime" property="createTime"/> <result column="note" property="note"/> <!-- 订单关联用户 --> <association property="user" javaType="com.User"> <id column="user_id" property="id"/> <result column="username" property="username"/> <result column="sex" property="sex"/> <result column="address" property="address"/> </association> </resultMap>

查询语句:

复制代码
1
2
3
4
5
6
7
<select id="findOrdersUser" resultType="com.OrdersCustom" resultMap="OrdersUserResultMap"> SELECT t1.*, t2.* FROM orders t1 LEFT JOIN t_user t2 WHERE t1.user_id=t2.id </select>

一对多查询(left join 主要是为了当多方为null时一方可以查)和多对多
目前有个需求:
条件筛选出一个A表的结果list,另一张B表的uuid,
他们之间的关联关系是 a.id=b.uuid,
若不存在关联的B对象则返回null.
因此考虑用左连接,不存在字段也不影响总的A表条数

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<resultMap type="com.User" id="userAndItemsResultMap"> <!-- 用户信息 --> <id column="user_id" property="id"/> <result column="username" property="username"/> <result column="sex" property="sex"/> <result column="address" property="address"/> <!-- 一个用户对应多个订单 --> <collection property="ordersList" ofType="com.Orders"> <id column="id" property="id"/> <result column="user_id" property="userid"/> <result column="number" property="number"/> <result column="createtime" property="createTime"/> <result column="note" property="note"/> <!-- 一个订单对应多个订单明细 --> <collection property="orderdetails" ofType="com.OrderDetail"> <id column="orderdetail_id" property="id"/> <result column="items_id" property="itemsId"/> <result column="items_num" property="itemsNum"/> <result column="orders_id" property="ordersId"/> <!-- 一个订单明细对应一个商品 --> <association property="items" javaType="com.Items"> <id column="items_id" property="id"/> <result column="items_name" property="itemsName"/> <result column="items_detail" property="detail"/> <result column="items_price" property="price"/> </association> </collection> </collection> </resultMap>

优化
before:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
SELECT a.name,a.uuid,a.app_name,a.app_uuid,a.release_uuid,a.release_name, a.layout_template_name,a.layout_template_uuid,a.layout_template_version, a.cluster_uuid,a.status,a.remark,a.delete_flag, a.create_time,a.create_user,a.update_time,a.update_user, d.department_code,d.deploy_type,d.department_name,d.namespace FROM app_instance as a LEFT JOIN dms_release as d ON a.release_uuid = d.uuid AND d.delete_flag=0 WHERE a.delete_flag=0 ORDER BY a.create_time DESC LIMIT 1,2

after:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
SELECT a.name,a.uuid,a.app_name,a.app_uuid,a.release_uuid,a.release_name, a.layout_template_name,a.layout_template_uuid,a.layout_template_version, a.cluster_uuid,a.status,a.remark,a.delete_flag, a.create_time,a.create_user,a.update_time,a.update_user, d.department_code,d.deploy_type,d.department_name,d.namespace FROM ( select * from app_instance where delete_flag=0 ORDER BY create_time desc LIMIT 1,2 ) as a LEFT JOIN dms_release as d ON a.release_uuid = d.uuid AND d.delete_flag=0

创建索引:

复制代码
1
2
ALTER TABLE app_instance ADD INDEX index_release_uuid (release_uuid)

思路:参考文献
引申改进SQL方案:点此链接
1.先筛选出符合条件的再进行join,而不是先全表join再筛选
2.加入关键选项的索引

遇到的问题及解决方案:
问题描述: 查询时父表和子表属性名一致,查出的数据被先查出的数据覆盖。
问题原因: 查询的SQL里选择的列中有两个列名为id的字段,导致封装成对象时出问题。
修改方法: 把其中一个列名id使用别名(这里把role表的列名id使用别名rid)。在这里插入图片描述
在这里插入图片描述

最后

以上就是甜美月光最近收集整理的关于mybatis查询子对象(一对一、一对多、互相嵌套查询等)的全部内容,更多相关mybatis查询子对象(一对一、一对多、互相嵌套查询等)内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(74)

评论列表共有 0 条评论

立即
投稿
返回
顶部