| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | <?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"> | 
					
						
							| 
									
										
										
										
											2018-10-07 14:16:47 +08:00
										 |  |  | <mapper namespace="com.ruoyi.system.mapper.SysRoleMapper"> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-07 14:16:47 +08:00
										 |  |  | 	<resultMap type="SysRole" id="SysRoleResult"> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 		<id     property="roleId"       column="role_id"        /> | 
					
						
							|  |  |  | 		<result property="roleName"     column="role_name"      /> | 
					
						
							|  |  |  | 		<result property="roleKey"      column="role_key"       /> | 
					
						
							|  |  |  | 		<result property="roleSort"     column="role_sort"      /> | 
					
						
							| 
									
										
										
										
											2018-09-03 08:45:08 +08:00
										 |  |  | 		<result property="dataScope"    column="data_scope"     /> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 		<result property="status"       column="status"         /> | 
					
						
							| 
									
										
										
										
											2018-09-03 08:45:08 +08:00
										 |  |  | 		<result property="delFlag"      column="del_flag"       /> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 		<result property="createBy"     column="create_by"      /> | 
					
						
							|  |  |  | 		<result property="createTime"   column="create_time"    /> | 
					
						
							|  |  |  | 		<result property="updateBy"     column="update_by"      /> | 
					
						
							|  |  |  | 		<result property="updateTime"   column="update_time"    /> | 
					
						
							|  |  |  | 		<result property="remark"       column="remark"         /> | 
					
						
							|  |  |  | 	</resultMap> | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2018-09-03 08:45:08 +08:00
										 |  |  | 	<sql id="selectRoleContactVo"> | 
					
						
							|  |  |  |         select distinct r.role_id, r.role_name, r.role_key, r.role_sort, r.data_scope, | 
					
						
							|  |  |  |             r.status, r.del_flag, r.create_time, r.remark  | 
					
						
							|  |  |  |         from sys_role r | 
					
						
							|  |  |  | 	        left join sys_user_role ur on ur.role_id = r.role_id | 
					
						
							|  |  |  | 	        left join sys_user u on u.user_id = ur.user_id | 
					
						
							|  |  |  | 	        left join sys_dept d on u.dept_id = d.dept_id | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  |     </sql> | 
					
						
							| 
									
										
										
										
											2018-09-03 08:45:08 +08:00
										 |  |  |      | 
					
						
							|  |  |  |     <sql id="selectRoleVo"> | 
					
						
							|  |  |  | 		select r.role_id, r.role_name, r.role_key, r.role_sort, r.data_scope, r.status, r.del_flag, r.create_time, r.remark  | 
					
						
							|  |  |  |         from sys_role r | 
					
						
							|  |  |  | 	</sql> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2018-10-07 14:16:47 +08:00
										 |  |  | 	<select id="selectRoleList" parameterType="SysRole" resultMap="SysRoleResult"> | 
					
						
							| 
									
										
										
										
											2018-09-03 08:45:08 +08:00
										 |  |  | 		<include refid="selectRoleContactVo"/> | 
					
						
							|  |  |  | 		where r.del_flag = '0' | 
					
						
							|  |  |  | 		<if test="roleName != null and roleName != ''"> | 
					
						
							|  |  |  | 			AND r.role_name like concat('%', #{roleName}, '%') | 
					
						
							|  |  |  | 		</if> | 
					
						
							|  |  |  | 		<if test="status != null and status != ''"> | 
					
						
							|  |  |  | 			AND r.status = #{status} | 
					
						
							|  |  |  | 		</if> | 
					
						
							|  |  |  | 		<if test="roleKey != null and roleKey != ''"> | 
					
						
							|  |  |  | 			AND r.role_key like concat('%', #{roleKey}, '%') | 
					
						
							|  |  |  | 		</if> | 
					
						
							|  |  |  | 		<if test="dataScope != null and dataScope != ''"> | 
					
						
							|  |  |  | 			AND r.data_scope = #{dataScope} | 
					
						
							|  |  |  | 		</if> | 
					
						
							|  |  |  | 		<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> | 
					
						
							|  |  |  | 			and date_format(r.create_time,'%y%m%d') >= date_format(#{params.beginTime},'%y%m%d') | 
					
						
							|  |  |  | 		</if> | 
					
						
							|  |  |  | 		<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> | 
					
						
							|  |  |  | 			and date_format(r.create_time,'%y%m%d') <= date_format(#{params.endTime},'%y%m%d') | 
					
						
							|  |  |  | 		</if> | 
					
						
							|  |  |  | 		<!-- 数据范围过滤 --> | 
					
						
							|  |  |  | 		${params.dataScope} | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 	</select> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-07 14:16:47 +08:00
										 |  |  | 	<select id="selectRolesByUserId" parameterType="Long" resultMap="SysRoleResult"> | 
					
						
							| 
									
										
										
										
											2018-09-03 08:45:08 +08:00
										 |  |  | 		<include refid="selectRoleContactVo"/> | 
					
						
							|  |  |  | 		WHERE r.del_flag = '0' and ur.user_id = #{userId} | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 	</select> | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2018-10-07 14:16:47 +08:00
										 |  |  | 	<select id="selectRoleById" parameterType="Long" resultMap="SysRoleResult"> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 		<include refid="selectRoleVo"/> | 
					
						
							| 
									
										
										
										
											2018-09-03 08:45:08 +08:00
										 |  |  | 		where r.del_flag = '0' and r.role_id = #{roleId} | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 	</select> | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2018-10-07 14:16:47 +08:00
										 |  |  | 	<select id="checkRoleNameUnique" parameterType="String" resultMap="SysRoleResult"> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 		<include refid="selectRoleVo"/> | 
					
						
							| 
									
										
										
										
											2020-08-05 14:21:31 +08:00
										 |  |  | 		 where r.role_name=#{roleName} limit 1 | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 	</select> | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2018-10-07 14:16:47 +08:00
										 |  |  | 	<select id="checkRoleKeyUnique" parameterType="String" resultMap="SysRoleResult"> | 
					
						
							| 
									
										
										
										
											2018-08-01 13:17:11 +08:00
										 |  |  | 		<include refid="selectRoleVo"/> | 
					
						
							| 
									
										
										
										
											2020-08-05 14:21:31 +08:00
										 |  |  | 		 where r.role_key=#{roleKey} limit 1 | 
					
						
							| 
									
										
										
										
											2018-08-01 13:17:11 +08:00
										 |  |  | 	</select> | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 	<delete id="deleteRoleById" parameterType="Long"> | 
					
						
							|  |  |  |  		delete from sys_role where role_id = #{roleId} | 
					
						
							|  |  |  |  	</delete> | 
					
						
							|  |  |  |  	 | 
					
						
							|  |  |  |  	<delete id="deleteRoleByIds" parameterType="Long"> | 
					
						
							| 
									
										
										
										
											2018-09-03 08:45:08 +08:00
										 |  |  |  	    update sys_role set del_flag = '2' where role_id in | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  |  		<foreach collection="array" item="roleId" open="(" separator="," close=")"> | 
					
						
							|  |  |  |  			#{roleId} | 
					
						
							|  |  |  |         </foreach>  | 
					
						
							|  |  |  |  	</delete> | 
					
						
							|  |  |  |  	 | 
					
						
							| 
									
										
										
										
											2018-10-07 14:16:47 +08:00
										 |  |  |  	<update id="updateRole" parameterType="SysRole"> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  |  		update sys_role | 
					
						
							|  |  |  |  		<set> | 
					
						
							|  |  |  |  			<if test="roleName != null and roleName != ''">role_name = #{roleName},</if> | 
					
						
							|  |  |  |  			<if test="roleKey != null and roleKey != ''">role_key = #{roleKey},</if> | 
					
						
							|  |  |  |  			<if test="roleSort != null and roleSort != ''">role_sort = #{roleSort},</if> | 
					
						
							| 
									
										
										
										
											2018-09-03 08:45:08 +08:00
										 |  |  |  			<if test="dataScope != null and dataScope != ''">data_scope = #{dataScope},</if> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  |  			<if test="status != null and status != ''">status = #{status},</if> | 
					
						
							| 
									
										
										
										
											2019-01-18 16:40:56 +08:00
										 |  |  |  			<if test="remark != null">remark = #{remark},</if> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  |  			<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> | 
					
						
							|  |  |  |  			update_time = sysdate() | 
					
						
							|  |  |  |  		</set> | 
					
						
							| 
									
										
										
										
											2018-07-23 20:34:01 +08:00
										 |  |  |  		where role_id = #{roleId} | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  | 	</update> | 
					
						
							|  |  |  |  	 | 
					
						
							| 
									
										
										
										
											2018-10-07 14:16:47 +08:00
										 |  |  |  	<insert id="insertRole" parameterType="SysRole" useGeneratedKeys="true" keyProperty="roleId"> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  |  		insert into sys_role( | 
					
						
							|  |  |  |  			<if test="roleId != null and roleId != 0">role_id,</if> | 
					
						
							|  |  |  |  			<if test="roleName != null and roleName != ''">role_name,</if> | 
					
						
							|  |  |  |  			<if test="roleKey != null and roleKey != ''">role_key,</if> | 
					
						
							|  |  |  |  			<if test="roleSort != null and roleSort != ''">role_sort,</if> | 
					
						
							| 
									
										
										
										
											2018-09-03 08:45:08 +08:00
										 |  |  |  			<if test="dataScope != null and dataScope != ''">data_scope,</if> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  |  			<if test="status != null and status != ''">status,</if> | 
					
						
							|  |  |  |  			<if test="remark != null and remark != ''">remark,</if> | 
					
						
							|  |  |  |  			<if test="createBy != null and createBy != ''">create_by,</if> | 
					
						
							|  |  |  |  			create_time | 
					
						
							|  |  |  |  		)values( | 
					
						
							|  |  |  |  			<if test="roleId != null and roleId != 0">#{roleId},</if> | 
					
						
							|  |  |  |  			<if test="roleName != null and roleName != ''">#{roleName},</if> | 
					
						
							|  |  |  |  			<if test="roleKey != null and roleKey != ''">#{roleKey},</if> | 
					
						
							|  |  |  |  			<if test="roleSort != null and roleSort != ''">#{roleSort},</if> | 
					
						
							| 
									
										
										
										
											2018-09-03 08:45:08 +08:00
										 |  |  |  			<if test="dataScope != null and dataScope != ''">#{dataScope},</if> | 
					
						
							| 
									
										
										
										
											2018-07-09 08:44:52 +08:00
										 |  |  |  			<if test="status != null and status != ''">#{status},</if> | 
					
						
							|  |  |  |  			<if test="remark != null and remark != ''">#{remark},</if> | 
					
						
							|  |  |  |  			<if test="createBy != null and createBy != ''">#{createBy},</if> | 
					
						
							|  |  |  |  			sysdate() | 
					
						
							|  |  |  |  		) | 
					
						
							|  |  |  | 	</insert> | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | </mapper>  |