RuoYi
2021-12-06 b6915631b79891543d265e46c79947760387f82b
src/main/resources/mybatis/system/SysMenuMapper.xml
@@ -12,7 +12,9 @@
      <result property="orderNum"       column="order_num"      />
      <result property="path"           column="path"           />
      <result property="component"      column="component"      />
      <result property="query"          column="query"          />
      <result property="isFrame"        column="is_frame"       />
      <result property="isCache"        column="is_cache"       />
      <result property="menuType"       column="menu_type"      />
      <result property="visible"        column="visible"        />
      <result property="status"         column="status"         />
@@ -26,7 +28,7 @@
   </resultMap>
   <sql id="selectMenuVo">
        select menu_id, menu_name, parent_id, order_num, path, component, is_frame, menu_type, visible, status, ifnull(perms,'') as perms, icon, create_time
        select menu_id, menu_name, parent_id, order_num, path, component, query, is_frame, is_cache, menu_type, visible, status, ifnull(perms,'') as perms, icon, create_time
      from sys_menu
    </sql>
    
@@ -47,32 +49,32 @@
   </select>
   
   <select id="selectMenuTreeAll" resultMap="SysMenuResult">
      select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.visible, m.status, ifnull(m.perms,'') as perms, m.is_frame, m.menu_type, m.icon, m.order_num, m.create_time
      select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.query, m.visible, m.status, ifnull(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time
      from sys_menu m where m.menu_type in ('M', 'C') and m.status = 0
      order by m.parent_id, m.order_num
   </select>
   
   <select id="selectMenuListByUserId" parameterType="SysMenu" resultMap="SysMenuResult">
      select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.visible, m.status, ifnull(m.perms,'') as perms, m.is_frame, m.menu_type, m.icon, m.order_num, m.create_time
      select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.query, m.visible, m.status, ifnull(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time
      from sys_menu m
      left join sys_role_menu rm on m.menu_id = rm.menu_id
      left join sys_user_role ur on rm.role_id = ur.role_id
      left join sys_role ro on ur.role_id = ro.role_id
      where ur.user_id = #{params.userId}
      <if test="menuName != null and menuName != ''">
            AND menu_name like concat('%', #{menuName}, '%')
            AND m.menu_name like concat('%', #{menuName}, '%')
      </if>
      <if test="visible != null and visible != ''">
            AND visible = #{visible}
            AND m.visible = #{visible}
      </if>
      <if test="status != null and status != ''">
            AND status = #{status}
            AND m.status = #{status}
      </if>
      order by m.parent_id, m.order_num
   </select>
    
    <select id="selectMenuTreeByUserId" parameterType="Long" resultMap="SysMenuResult">
      select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.visible, m.status, ifnull(m.perms,'') as perms, m.is_frame, m.menu_type, m.icon, m.order_num, m.create_time
      select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.query, m.visible, m.status, ifnull(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time
      from sys_menu m
          left join sys_role_menu rm on m.menu_id = rm.menu_id
          left join sys_user_role ur on rm.role_id = ur.role_id
@@ -82,12 +84,14 @@
      order by m.parent_id, m.order_num
   </select>
   
   <select id="selectMenuListByRoleId" parameterType="Long" resultType="Integer">
      select m.menu_id, m.parent_id
   <select id="selectMenuListByRoleId" resultType="Long">
      select m.menu_id
      from sys_menu m
            left join sys_role_menu rm on m.menu_id = rm.menu_id
        where rm.role_id = #{roleId}
           and m.menu_id not in (select m.parent_id from sys_menu m inner join sys_role_menu rm on m.menu_id = rm.menu_id and rm.role_id = #{roleId})
            <if test="menuCheckStrictly">
              and m.menu_id not in (select m.parent_id from sys_menu m inner join sys_role_menu rm on m.menu_id = rm.menu_id and rm.role_id = #{roleId})
            </if>
      order by m.parent_id, m.order_num
   </select>
   
@@ -118,7 +122,7 @@
   
   <select id="checkMenuNameUnique" parameterType="SysMenu" resultMap="SysMenuResult">
      <include refid="selectMenuVo"/>
      where menu_name=#{menuName} and parent_id = #{parentId}
      where menu_name=#{menuName} and parent_id = #{parentId} limit 1
   </select>
   
   <update id="updateMenu" parameterType="SysMenu">
@@ -128,8 +132,10 @@
         <if test="parentId != null">parent_id = #{parentId},</if>
         <if test="orderNum != null and orderNum != ''">order_num = #{orderNum},</if>
         <if test="path != null and path != ''">path = #{path},</if>
         <if test="component != null and component != ''">component = #{component},</if>
         <if test="component != null">component = #{component},</if>
         <if test="query != null">query = #{query},</if>
         <if test="isFrame != null and isFrame != ''">is_frame = #{isFrame},</if>
         <if test="isCache != null and isCache != ''">is_cache = #{isCache},</if>
         <if test="menuType != null and menuType != ''">menu_type = #{menuType},</if>
         <if test="visible != null">visible = #{visible},</if>
         <if test="status != null">status = #{status},</if>
@@ -150,7 +156,9 @@
      <if test="orderNum != null and orderNum != ''">order_num,</if>
      <if test="path != null and path != ''">path,</if>
      <if test="component != null and component != ''">component,</if>
      <if test="query != null and query != ''">query,</if>
      <if test="isFrame != null and isFrame != ''">is_frame,</if>
      <if test="isCache != null and isCache != ''">is_cache,</if>
      <if test="menuType != null and menuType != ''">menu_type,</if>
      <if test="visible != null">visible,</if>
      <if test="status != null">status,</if>
@@ -166,7 +174,9 @@
      <if test="orderNum != null and orderNum != ''">#{orderNum},</if>
      <if test="path != null and path != ''">#{path},</if>
      <if test="component != null and component != ''">#{component},</if>
      <if test="query != null and query != ''">#{query},</if>
      <if test="isFrame != null and isFrame != ''">#{isFrame},</if>
      <if test="isCache != null and isCache != ''">#{isCache},</if>
      <if test="menuType != null and menuType != ''">#{menuType},</if>
      <if test="visible != null">#{visible},</if>
      <if test="status != null">#{status},</if>