update 优化 大数据量下join卡顿问题 使用子查询提高性能
This commit is contained in:
parent
3dff529920
commit
a4fe077a23
@ -18,13 +18,6 @@ import java.util.List;
|
|||||||
*/
|
*/
|
||||||
public interface SysMenuMapper extends BaseMapperPlus<SysMenu, SysMenuVo> {
|
public interface SysMenuMapper extends BaseMapperPlus<SysMenu, SysMenuVo> {
|
||||||
|
|
||||||
/**
|
|
||||||
* 根据用户所有权限
|
|
||||||
*
|
|
||||||
* @return 权限列表
|
|
||||||
*/
|
|
||||||
List<String> selectMenuPerms();
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据用户查询系统菜单列表
|
* 根据用户查询系统菜单列表
|
||||||
*
|
*
|
||||||
|
@ -75,7 +75,7 @@ public class SysMenuServiceImpl implements ISysMenuService {
|
|||||||
.orderByAsc(SysMenu::getOrderNum));
|
.orderByAsc(SysMenu::getOrderNum));
|
||||||
} else {
|
} else {
|
||||||
QueryWrapper<SysMenu> wrapper = Wrappers.query();
|
QueryWrapper<SysMenu> wrapper = Wrappers.query();
|
||||||
wrapper.eq("sur.user_id", userId)
|
wrapper.inSql("r.role_id", "select role_id from sys_user_role where user_id = " + userId)
|
||||||
.like(StringUtils.isNotBlank(menu.getMenuName()), "m.menu_name", menu.getMenuName())
|
.like(StringUtils.isNotBlank(menu.getMenuName()), "m.menu_name", menu.getMenuName())
|
||||||
.eq(StringUtils.isNotBlank(menu.getVisible()), "m.visible", menu.getVisible())
|
.eq(StringUtils.isNotBlank(menu.getVisible()), "m.visible", menu.getVisible())
|
||||||
.eq(StringUtils.isNotBlank(menu.getStatus()), "m.status", menu.getStatus())
|
.eq(StringUtils.isNotBlank(menu.getStatus()), "m.status", menu.getStatus())
|
||||||
|
@ -103,7 +103,7 @@ public class SysRoleServiceImpl implements ISysRoleService {
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public List<SysRoleVo> selectRolesAuthByUserId(Long userId) {
|
public List<SysRoleVo> selectRolesAuthByUserId(Long userId) {
|
||||||
List<SysRoleVo> userRoles = baseMapper.selectRolePermissionByUserId(userId);
|
List<SysRoleVo> userRoles = baseMapper.selectRolesByUserId(userId);
|
||||||
List<SysRoleVo> roles = selectRoleAll();
|
List<SysRoleVo> roles = selectRoleAll();
|
||||||
// 使用HashSet提高查找效率
|
// 使用HashSet提高查找效率
|
||||||
Set<Long> userRoleIds = userRoles.stream().map(SysRoleVo::getRoleId).collect(Collectors.toSet());
|
Set<Long> userRoleIds = userRoles.stream().map(SysRoleVo::getRoleId).collect(Collectors.toSet());
|
||||||
@ -123,7 +123,7 @@ public class SysRoleServiceImpl implements ISysRoleService {
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public Set<String> selectRolePermissionByUserId(Long userId) {
|
public Set<String> selectRolePermissionByUserId(Long userId) {
|
||||||
List<SysRoleVo> perms = baseMapper.selectRolePermissionByUserId(userId);
|
List<SysRoleVo> perms = baseMapper.selectRolesByUserId(userId);
|
||||||
Set<String> permsSet = new HashSet<>();
|
Set<String> permsSet = new HashSet<>();
|
||||||
for (SysRoleVo perm : perms) {
|
for (SysRoleVo perm : perms) {
|
||||||
if (ObjectUtil.isNotNull(perm)) {
|
if (ObjectUtil.isNotNull(perm)) {
|
||||||
|
@ -12,8 +12,7 @@
|
|||||||
m.perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time
|
m.perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time
|
||||||
from sys_menu m
|
from sys_menu m
|
||||||
left join sys_role_menu rm on m.menu_id = rm.menu_id
|
left join sys_role_menu rm on m.menu_id = rm.menu_id
|
||||||
left join sys_user_role sur on rm.role_id = sur.role_id
|
left join sys_role r on sur.role_id = r.role_id
|
||||||
left join sys_role ro on sur.role_id = ro.role_id
|
|
||||||
${ew.getCustomSqlSegment}
|
${ew.getCustomSqlSegment}
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
@ -34,14 +33,10 @@
|
|||||||
m.order_num,
|
m.order_num,
|
||||||
m.create_time
|
m.create_time
|
||||||
from sys_menu m
|
from sys_menu m
|
||||||
left join sys_role_menu rm on m.menu_id = rm.menu_id
|
left join sys_role_menu rm on m.menu_id = rm.menu_id and m.status = '0'
|
||||||
left join sys_user_role sur on rm.role_id = sur.role_id
|
left join sys_role r on rm.role_id = r.role_id and r.status = '0'
|
||||||
left join sys_role ro on sur.role_id = ro.role_id
|
where m.menu_type in ('M', 'C')
|
||||||
left join sys_user u on sur.user_id = u.user_id
|
and r.role_id in (select role_id from sys_user_role where user_id = #{userId})
|
||||||
where u.user_id = #{userId}
|
|
||||||
and m.menu_type in ('M', 'C')
|
|
||||||
and m.status = '0'
|
|
||||||
and ro.status = '0'
|
|
||||||
order by m.parent_id, m.order_num
|
order by m.parent_id, m.order_num
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
@ -57,22 +52,12 @@
|
|||||||
order by m.parent_id, m.order_num
|
order by m.parent_id, m.order_num
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select id="selectMenuPerms" resultType="String">
|
|
||||||
select distinct m.perms
|
|
||||||
from sys_menu m
|
|
||||||
left join sys_role_menu rm on m.menu_id = rm.menu_id
|
|
||||||
left join sys_user_role sur on rm.role_id = sur.role_id
|
|
||||||
</select>
|
|
||||||
|
|
||||||
<select id="selectMenuPermsByUserId" parameterType="Long" resultType="String">
|
<select id="selectMenuPermsByUserId" parameterType="Long" resultType="String">
|
||||||
select distinct m.perms
|
select distinct m.perms
|
||||||
from sys_menu m
|
from sys_menu m
|
||||||
left join sys_role_menu rm on m.menu_id = rm.menu_id
|
left join sys_role_menu rm on m.menu_id = rm.menu_id and m.status = '0'
|
||||||
left join sys_user_role sur on rm.role_id = sur.role_id
|
left join sys_role r on r.role_id = rm.role_id and r.status = '0'
|
||||||
left join sys_role r on r.role_id = sur.role_id
|
where r.role_id in (select role_id from sys_user_role where user_id = #{userId})
|
||||||
where m.status = '0'
|
|
||||||
and r.status = '0'
|
|
||||||
and sur.user_id = #{userId}
|
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select id="selectMenuPermsByRoleId" parameterType="Long" resultType="String">
|
<select id="selectMenuPermsByRoleId" parameterType="Long" resultType="String">
|
||||||
|
@ -48,9 +48,7 @@
|
|||||||
r.data_scope,
|
r.data_scope,
|
||||||
r.status
|
r.status
|
||||||
from sys_role r
|
from sys_role r
|
||||||
left join sys_user_role sur on sur.role_id = r.role_id
|
WHERE r.del_flag = '0' and r.role_id in (select role_id from sys_user_role where user_id = #{userId})
|
||||||
left join sys_user u on u.user_id = sur.user_id
|
|
||||||
WHERE r.del_flag = '0' and sur.user_id = #{userId}
|
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select id="selectRoleById" resultMap="SysRoleResult">
|
<select id="selectRoleById" resultMap="SysRoleResult">
|
||||||
|
Loading…
x
Reference in New Issue
Block a user