系统菜单搜索优化2

master
yaoxin 2024-04-12 16:47:51 +08:00
parent 35a07973e7
commit 58d903ac6d
3 changed files with 37 additions and 1 deletions

View File

@ -23,6 +23,7 @@ public interface SysMenuMapper extends BaseMapper<SysMenu> {
public List<SysMenu> selectMenuList (SysMenu menu); public List<SysMenu> selectMenuList (SysMenu menu);
public List<SysMenu> selectSysMenuList (@Param("longs") List<Long> longs); public List<SysMenu> selectSysMenuList (@Param("longs") List<Long> longs);
public List<SysMenu> selectSysChdMenuList (@Param("longs") List<Long> longs);
/** /**
* *

View File

@ -68,6 +68,22 @@ public class SysMenuServiceImpl extends ServiceImpl<SysMenuMapper, SysMenu> impl
return sysMenus; return sysMenus;
} }
public List<SysMenu> selectSysChdMenuList(List<SysMenu> menuList){
List<Long> longs = menuList.stream()
.map(menu -> menu.getMenuId())
.toList();
List<SysMenu> sysMenus = menuMapper.selectSysChdMenuList(longs);
if (sysMenus!=null && sysMenus.size()!=0){
List<SysMenu> sysMenus1 = selectSysMenuList(sysMenus);
if (sysMenus1 != null){
sysMenus.addAll(sysMenus1);
}
}else{
return null;
}
return sysMenus;
}
/** /**
* *
* *
@ -81,7 +97,15 @@ public class SysMenuServiceImpl extends ServiceImpl<SysMenuMapper, SysMenu> impl
// 管理员显示所有菜单信息 // 管理员显示所有菜单信息
if (SysUser.isAdmin(userId)) { if (SysUser.isAdmin(userId)) {
menuList = menuMapper.selectMenuList(menu); menuList = menuMapper.selectMenuList(menu);
menuList.addAll(selectSysMenuList(menuList)); List<SysMenu> sysMenus1 = selectSysMenuList(menuList);
if (sysMenus1!=null && sysMenus1.size()!=0){
menuList.addAll(sysMenus1);
}
List<SysMenu> sysMenus = selectSysChdMenuList(menuMapper.selectMenuList(menu));
if (sysMenus!=null && sysMenus.size()!=0){
menuList.addAll(sysMenus);
}
} else { } else {
menu.getParams().put("userId", userId); menu.getParams().put("userId", userId);
menuList = menuMapper.selectMenuListByUserId(menu); menuList = menuMapper.selectMenuListByUserId(menu);

View File

@ -196,6 +196,17 @@
</where> </where>
order by parent_id, order_num order by parent_id, order_num
</select> </select>
<select id="selectSysChdMenuList" resultType="com.muyu.system.domain.SysMenu">
<include refid="selectMenuVo"/>
<where>
parent_id in (
<foreach collection="longs" separator="," item="id">
#{id}
</foreach>
)
</where>
order by parent_id, order_num
</select>
<update id="updateMenu" parameterType="com.muyu.system.domain.SysMenu"> <update id="updateMenu" parameterType="com.muyu.system.domain.SysMenu">
update sys_menu update sys_menu