| <?xml version="1.0" encoding="UTF-8"?> | 
| <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | 
| <mapper namespace="com.dsh.course.mapper.UserMapper"> | 
|   | 
|     <!-- 通用查询映射结果 --> | 
|     <resultMap id="BaseResultMap" type="com.dsh.guns.modular.system.model.User"> | 
|         <id column="id" property="id" /> | 
|         <result column="avatar" property="avatar" /> | 
|         <result column="account" property="account" /> | 
|         <result column="password" property="password" /> | 
|         <result column="salt" property="salt" /> | 
|         <result column="name" property="name" /> | 
|         <result column="birthday" property="birthday" /> | 
|         <result column="sex" property="sex" /> | 
|         <result column="email" property="email" /> | 
|         <result column="phone" property="phone" /> | 
|         <result column="roleid" property="roleid" /> | 
|         <result column="deptid" property="deptid" /> | 
|         <result column="status" property="status" /> | 
|         <result column="createtime" property="createtime" /> | 
|         <result column="version" property="version" /> | 
|         <result column="objectType" property="objectType"/> | 
|         <result column="objectId" property="objectId"/> | 
|     </resultMap> | 
|   | 
|     <sql id="Base_Column_List"> | 
|         id, account, name, birthday, sex, email, avatar, | 
|         phone, roleid, | 
|         deptid, status, | 
|         createtime, version | 
|     </sql> | 
|   | 
|     <sql id="Base_Column_List_With_Pwd"> | 
|         id, account, name, birthday,password, sex, email, avatar, | 
|         phone, roleid,salt, | 
|         deptid, status, | 
|         createtime, version,objectType,objectId | 
|     </sql> | 
|   | 
|     <select id="selectUsers" resultType="map"> | 
|         select | 
|         <include refid="Base_Column_List" /> | 
|         from sys_user | 
|         where status != 3 | 
|         <if test="name != null and name != ''"> | 
|             and (phone like CONCAT('%',#{name},'%') | 
|             or account like CONCAT('%',#{name},'%') | 
|             or name like CONCAT('%',#{name},'%')) | 
|         </if> | 
|         <if test="deptid != null and deptid != 0"> | 
|             and (deptid = #{deptid} or deptid in ( select id from sys_dept where pids like CONCAT('%[', #{deptid}, ']%') )) | 
|         </if> | 
|         <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|             and (createTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|         </if> | 
|     </select> | 
|   | 
|     <update id="setStatus"> | 
|         update sys_user set status = #{status} where id = | 
|         #{userId} | 
|     </update> | 
|   | 
|     <update id="changePwd"> | 
|         update sys_user set password = #{pwd} where id = | 
|         #{userId} | 
|     </update> | 
|   | 
|     <update id="setRoles"> | 
|         update sys_user set roleid = #{roleIds} where id = | 
|         #{userId} | 
|     </update> | 
|   | 
|     <select id="getByAccount" resultType="com.dsh.guns.modular.system.model.User"> | 
|         select | 
|         <include refid="Base_Column_List_With_Pwd" /> | 
|         from sys_user where account = #{account} and status != 3 | 
|     </select> | 
|   | 
|     <!--根据角色判断菜单有"首页"的数量--> | 
|     <select id="getMenuNumByRole" resultType="java.lang.Integer"> | 
|         SELECT IFNULL(COUNT(menuid),0) as num from sys_relation where roleid in (#{roleStr}) and menuid = 2 | 
|     </select> | 
|   | 
|     <select id="getUserListPage" resultType="map" parameterType="com.baomidou.mybatisplus.extension.plugins.pagination.Page"> | 
|         SELECT * FROM (select CASE when d2.simplename is null then d1.simplename else d2.simplename end as parentName, | 
|          uu.sex as sexName, | 
|         d1.simplename as deptName, uu.status  as statusName, | 
|         rr.roleName, | 
|         DATE_FORMAT(uu.createtime, '%Y-%m-%d %H:%i:%s') as createtime1, | 
|         uu.* from sys_user as uu | 
|         LEFT JOIN sys_dept as d1 on d1.id = uu.deptid | 
|         LEFT JOIN sys_dept as d2 on d2.id = d1.pid | 
|         LEFT JOIN (select s.id,s.name,GROUP_CONCAT(r.name) as roleName from sys_user s | 
|         left join sys_role r on find_in_set(r.id,s.roleid) group by s.id) as rr on rr.id = uu.id | 
|         ) as o | 
|         <where> | 
|             o.status != 3 | 
|             <if test="name != null and name != ''"> | 
|                 and (o.phone like CONCAT('%',#{name},'%') | 
|                 or o.account like CONCAT('%',#{name},'%') | 
|                 or o.name like CONCAT('%',#{name},'%')) | 
|             </if> | 
|             <if test="deptid != null and deptid != 0"> | 
|                 and (o.deptid = #{deptid} or o.deptid in ( select id from sys_dept where pids like CONCAT('%[', #{deptid}, ']%') )) | 
|             </if> | 
|             <if test="beginTime != null and beginTime != '' and endTime != null and endTime != ''"> | 
|                 and (o.createTime between CONCAT(#{beginTime},' 00:00:00') and CONCAT(#{endTime},' 23:59:59')) | 
|             </if> | 
|         </where> | 
|         order by o.id desc | 
|     </select> | 
|   | 
| </mapper> |