huminmin
2 天以前 450b4bc51e7df7621155dc0c5592a6d11a935551
src/main/resources/mapper/system/SysUserMapper.xml
@@ -15,6 +15,7 @@
        <result property="password"     column="password"     />
        <result property="status"       column="status"       />
        <result property="delFlag"      column="del_flag"     />
        <result property="aiEnabled"    column="ai_enabled"   />
        <result property="loginIp"      column="login_ip"     />
        <result property="loginDate"    column="login_date"   />
        <result property="createBy"     column="create_by"    />
@@ -24,6 +25,7 @@
        <result property="remark"       column="remark"       />
      <result property="deptNames"       column="dept_names"       />
      <result property="tenantId"       column="tenant_id"       />
      <result property="roleNames"       column="role_names"       />
        <association property="dept"    javaType="com.ruoyi.project.system.domain.SysDept"         resultMap="deptResult" />
        <collection  property="roles"   javaType="java.util.List"  resultMap="RoleResult" />
    </resultMap>
@@ -48,7 +50,7 @@
    </resultMap>
   <sql id="selectUserVo">
        select u.user_id, u.user_name, u.nick_name, u.email, u.avatar, u.phonenumber, u.password, u.sex, u.status, u.del_flag, u.login_ip, u.login_date, u.create_by, u.create_time, u.remark,
        select u.user_id, u.user_name, u.nick_name, u.email, u.avatar, u.phonenumber, u.password, u.sex, u.status, u.del_flag, u.ai_enabled, u.login_ip, u.login_date, u.create_by, u.create_time, u.remark,
        r.role_id, r.role_name, r.role_key, r.role_sort, r.data_scope, r.status as role_status,u.tenant_id
        from sys_user u
          left join sys_user_role ur on u.user_id = ur.user_id
@@ -96,6 +98,7 @@
      </if>
      <!-- 数据范围过滤 -->
      ${params.dataScope}
      ORDER BY u.create_time DESC
   </select>
   <select id="selectAllocatedList" parameterType="com.ruoyi.project.system.domain.SysUser" resultMap="SysUserResult">
@@ -129,17 +132,20 @@
      </if>
      <!-- 数据范围过滤 -->
      ${params.dataScope}
      ORDER BY u.create_time DESC
   </select>
   <select id="selectUserByUserName" parameterType="String" resultMap="SysUserResult">
       <include refid="selectUserVo"/>
      where u.user_name = #{userName} and u.del_flag = '0'
      ORDER BY u.create_time DESC
   </select>
   <select id="selectUserById" parameterType="Long" resultMap="SysUserResult">
      <include refid="selectUserVo"/>
      where u.user_id = #{userId}
      and u.del_flag = '0'
      ORDER BY u.create_time DESC
   </select>
   <select id="checkUserNameUnique" parameterType="String" resultMap="SysUserResult">
@@ -164,6 +170,7 @@
            </if>
            and u.del_flag = '0'
        </where>
        ORDER BY u.create_time DESC
    </select>
   <select id="selectRegistrantIds" resultType="com.ruoyi.project.system.domain.SysUser">
      SELECT user_id, nick_name FROM sys_user
@@ -178,6 +185,7 @@
            1=0  <!-- 空列表时返回空结果 -->
         </if>
      </where>
      ORDER BY sys_user.create_time DESC
   </select>
   <select id="selectUsersByIds" resultType="com.ruoyi.project.system.domain.SysUser">
      SELECT user_id, nick_name
@@ -187,6 +195,7 @@
         #{id}
      </foreach>
      and del_flag = '0'
      ORDER BY sys_user.create_time DESC
   </select>
   <select id="selectUserByNickName" resultType="com.ruoyi.project.system.domain.SysUser"
         parameterType="java.lang.String">
@@ -280,7 +289,31 @@
        and sr.status = '0'
        and su.status = '0'
        and su.del_flag = '0'
      ORDER BY su.create_time DESC
   </select>
   <select id="selectUserListWithDetail" resultMap="SysUserResult">
      select u.user_id, u.nick_name, u.user_name, u.status, u.del_flag,
             dept_agg.dept_names,
             role_agg.role_names
      from sys_user u
      left join (
          SELECT ud.user_id, GROUP_CONCAT(d.dept_name SEPARATOR ', ') AS dept_names
          FROM sys_user_dept ud
          LEFT JOIN sys_dept d ON ud.dept_id = d.dept_id
          WHERE d.del_flag = '0' AND d.status = '0'
          GROUP BY ud.user_id
      ) dept_agg on dept_agg.user_id = u.user_id
      left join (
          SELECT ur.user_id, GROUP_CONCAT(r.role_name SEPARATOR ', ') AS role_names
          FROM sys_user_role ur
          LEFT JOIN sys_role r ON ur.role_id = r.role_id
          WHERE r.del_flag = '0' AND r.status = '0'
          GROUP BY ur.user_id
      ) role_agg on role_agg.user_id = u.user_id
      where u.del_flag = '0' AND u.status = '0'
   </select>
   <select id="getUserByPerms" resultType="java.lang.Long">
      select distinct t5.user_id
      from sys_role_menu t1