package cn.lili.modules.permission.mapper; import cn.lili.modules.permission.entity.dos.Menu; import cn.lili.modules.permission.entity.vo.UserMenuVO; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import org.apache.ibatis.annotations.Select; import java.util.List; /** * 菜单数据处理层 * * @author Chopper * @since 2020-11-22 09:17 */ public interface MenuMapper extends BaseMapper { /** * 根据用户获取菜单列表 * * @param userId 用户ID * @return 菜单列表 */ @Select("SELECT menu.* FROM li_menu AS menu WHERE menu.id IN (" + "SELECT rm.menu_id FROM li_role_menu AS rm WHERE rm.role_id IN (" + "SELECT ur.role_id FROM li_user_role AS ur WHERE ur.user_id=#{userId}) OR rm.role_id IN (" + "SELECT dr.role_id FROM li_department_role AS dr WHERE dr.department_id =(" + "SELECT department_id FROM li_admin_user AS au WHERE au.id = #{userId})))") List findByUserId(String userId); /** * 根据用户获取菜单权限 * * @param userId 用户ID * @return 用户菜单VO列表 */ @Select("SELECT rm.is_super as is_super,m.*FROM li_menu AS m INNER JOIN li_role_menu AS rm ON rm.menu_id=m.id WHERE rm.role_id IN (" + "SELECT ur.role_id FROM li_user_role AS ur WHERE ur.user_id=#{userId}) OR rm.role_id IN (" + "SELECT dr.role_id FROM li_department_role AS dr INNER JOIN li_admin_user AS au ON au.department_id=dr.department_id " + "WHERE au.id=#{userId}) GROUP BY m.id,rm.is_super ORDER BY rm.is_super desc") List getUserRoleMenu(String userId); }