mybatis查询子对象(一对一、一对多、互相嵌套查询等)

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



        
        
        
         
         
         
         
            
             
             
             
         
 

查询语句:


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


        
        
        
        
        
        
        
                 
                 
                
                
                
                
                
                    
                    
                    
                    
                    
                    
                        
                        
                        
                        
                    
                
         
 

优化
before:

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:

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

创建索引:

ALTER TABLE app_instance ADD INDEX index_release_uuid (release_uuid)

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

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

你可能感兴趣的:(mybatis,mybatis查询子对象,mybatis查询子对象为空,一对多多对多的查询)