一起看海呦 2023-06-14 09:29 采纳率: 100%
浏览 21
已结题

mysql sql 优化


select * from (
select ru.parent_id as parentId,ru.function_name as name,ru.id ,1 as 
incidenceRelation,ru.sort  
from rmc_sys_permission ru
left join rmc_sys_role_permission ruo 
on ru.id=ruo.permission_id and ruo.role_id=#{roleId}
where ruo.role_id is null  
union all
select ru.parent_id as parentId,ru.function_name as name,ru.id ,2 as incidenceRelation,ru.sort
from rmc_sys_permission ru
left join rmc_sys_role_permission ruo 
on ru.id=ruo.permission_id and ruo.role_id=#{roleId}  
) as r order by r.sort asc
  • 写回答

5条回答 默认 最新

  • 开发技术控 2023-06-14 09:39
    关注

    JOIN ON条件代替WHERE
    UNION ALL代替UNION

    select ru.parent_id as parentId,ru.function_name as name,ru.id ,1 as  
    incidenceRelation,ru.sort  
    from rmc_sys_permission ru  
    left join rmc_sys_role_permission ruo  
    on ru.id=ruo.permission_id and ruo.role_id=#{roleId}
    where ruo.role_id is null
    UNION ALL 
    select ru.parent_id as parentId,ru.function_name as name,ru.id ,2 as incidenceRelation,ru.sort
    from rmc_sys_permission ru
    left join rmc_sys_role_permission ruo
    on ru.id=ruo.permission_id and ruo.role_id=#{roleId}  
    order by sort asc 
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 6月22日
  • 已采纳回答 6月14日
  • 创建了问题 6月14日