一起看海呦 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日

悬赏问题

  • ¥15 angular项目错误
  • ¥20 需要帮我远程操控一下,运行一下我的那个代码,我觉得我无能为力了
  • ¥20 有偿:在ubuntu上安装arduino以及其常用库文件。
  • ¥15 请问用arcgis处理一些数据和图形,通常里面有一个根据点划泰森多边形的命令,直接划的弊端是只能执行一个完整的边界,但是我们有时候会用到需要在有很多边界内利用点来执行划泰森多边形的命令
  • ¥30 在wave2foam中执行setWaveField时遇到了如下的浮点异常问题,请问该如何解决呢?
  • ¥750 关于一道数论方面的问题,求解答!(关键词-数学方法)
  • ¥200 csgo2的viewmatrix值是否还有别的获取方式
  • ¥15 Stable Diffusion,用Ebsynth utility在视频选帧图重绘,第一步报错,蒙版和帧图没法生成,怎么处理啊
  • ¥15 请把下列每一行代码完整地读懂并注释出来
  • ¥15 寻找公式识别开发,自动识别整页文档、图像公式的软件