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
mysql sql 优化
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
5条回答 默认 最新
开发技术控 2023-06-14 09:39关注JOIN ON条件代替WHERE
UNION ALL代替UNIONselect 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本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报