|
|
@@ -0,0 +1,195 @@
|
|
|
+<?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.dk.mdm.mapper.mst.RoleFunMapper">
|
|
|
+
|
|
|
+ <!-- 通用设置 -->
|
|
|
+ <!-- 通用查询列 -->
|
|
|
+ <sql id="Base_Column_List">
|
|
|
+ role_id, fun_uuid, app_code, cp_id, op_create_time, op_create_user_id, op_update_time, op_update_user_id, op_app_code, op_timestamp, op_db_user
|
|
|
+ </sql>
|
|
|
+
|
|
|
+ <!-- 通用查询映射结果 -->
|
|
|
+ <resultMap id="BaseResultMap" type="com.dk.mdm.model.pojo.mst.RoleFun">
|
|
|
+ <id column="role_id" property="roleId"/>
|
|
|
+ <result column="fun_uuid" property="funUuid" typeHandler="UuidTypeHandler"/>
|
|
|
+ <result column="app_code" property="appCode"/>
|
|
|
+ <result column="cp_id" property="cpId"/>
|
|
|
+ <result column="op_create_time" property="opCreateTime" typeHandler="TimestampTypeHandler"/>
|
|
|
+ <result column="op_create_user_id" property="opCreateUserId" typeHandler="UuidTypeHandler"/>
|
|
|
+ <result column="op_update_time" property="opUpdateTime" typeHandler="TimestampTypeHandler"/>
|
|
|
+ <result column="op_update_user_id" property="opUpdateUserId" typeHandler="UuidTypeHandler"/>
|
|
|
+ <result column="op_app_code" property="opAppCode"/>
|
|
|
+ <result column="op_timestamp" property="opTimestamp" typeHandler="TimestampTypeHandler"/>
|
|
|
+ <result column="op_db_user" property="opDbUser"/>
|
|
|
+ </resultMap>
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ <resultMap id="BaseResultMap2" type="com.dk.mdm.model.pojo.mst.RoleFun">
|
|
|
+ <id column="id" property="id"/>
|
|
|
+ <result column="menuUuid" property="menuUuid" typeHandler="UuidTypeHandler"/>
|
|
|
+ <result column="menuName" property="menuName" />
|
|
|
+ <result column="appCode" property="appCode" />
|
|
|
+ <result column="parentId" property="parentId" typeHandler="UuidTypeHandler"/>
|
|
|
+ <result column="flgMenu" property="flgMenu" />
|
|
|
+ <result column="roleId" property="roleId" typeHandler="UuidTypeHandler"/>
|
|
|
+ <result column="funUuid" property="funUuid" typeHandler="UuidTypeHandler"/>
|
|
|
+ <result column="checked" property="checked" />
|
|
|
+
|
|
|
+ <result column="subMenus" property="subMenus" typeHandler="JsonTypeHandler"/>
|
|
|
+
|
|
|
+ </resultMap>
|
|
|
+
|
|
|
+ <!-- 通用条件列 -->
|
|
|
+ <sql id="Condition">
|
|
|
+ <where>
|
|
|
+ <if test="funUuid != null and funUuid != ''">
|
|
|
+ AND fun_uuid = #{funUuid}
|
|
|
+ </if>
|
|
|
+ <if test="appCode != null and appCode != ''">
|
|
|
+ AND app_code = #{appCode}
|
|
|
+ </if>
|
|
|
+ <if test="cpId != null">
|
|
|
+ AND cp_id = #{cpId}
|
|
|
+ </if>
|
|
|
+ <if test="opCreateTime != null">
|
|
|
+ AND op_create_time = #{opCreateTime}
|
|
|
+ </if>
|
|
|
+ <if test="opCreateUserId != null and opCreateUserId != ''">
|
|
|
+ AND op_create_user_id = #{opCreateUserId}
|
|
|
+ </if>
|
|
|
+ <if test="opUpdateTime != null">
|
|
|
+ AND op_update_time = #{opUpdateTime}
|
|
|
+ </if>
|
|
|
+ <if test="opUpdateUserId != null and opUpdateUserId != ''">
|
|
|
+ AND op_update_user_id = #{opUpdateUserId}
|
|
|
+ </if>
|
|
|
+ <if test="opAppCode != null and opAppCode != ''">
|
|
|
+ AND op_app_code = #{opAppCode}
|
|
|
+ </if>
|
|
|
+ <if test="opTimestamp != null">
|
|
|
+ AND op_timestamp = #{opTimestamp}
|
|
|
+ </if>
|
|
|
+ <if test="opDbUser != null and opDbUser != ''">
|
|
|
+ AND op_db_user = #{opDbUser}
|
|
|
+ </if>
|
|
|
+ </where>
|
|
|
+ </sql>
|
|
|
+
|
|
|
+ <sql id="idsForeach">
|
|
|
+ <!-- 根据主键roleId批量操作 -->
|
|
|
+ WHERE role_id in
|
|
|
+ <foreach collection="ids" index="index" item="item" separator="," open="(" close=")">
|
|
|
+ #{item}
|
|
|
+ </foreach>
|
|
|
+ </sql>
|
|
|
+
|
|
|
+ <!-- 查询表t_mst_role_fun,(条件查询+分页)列表 -->
|
|
|
+ <select id="selectByCond" resultMap="BaseResultMap">
|
|
|
+ SELECT
|
|
|
+ <include refid="Base_Column_List"/>
|
|
|
+ FROM dkic_b.t_mst_role_fun
|
|
|
+ <include refid="Condition"/>
|
|
|
+ <if test="pageSize != null and currentPage != null and pageSize != 0 and currentPage != 0">
|
|
|
+ limit #{end} offset #{start}
|
|
|
+ </if>
|
|
|
+ </select>
|
|
|
+
|
|
|
+ <!-- 查询表t_mst_role_fun,(条件查询)个数 -->
|
|
|
+ <select id="countByCond" resultType="Long">
|
|
|
+ SELECT
|
|
|
+ count(1)
|
|
|
+ FROM dkic_b.t_mst_role_fun
|
|
|
+ <include refid="Condition"/>
|
|
|
+ </select>
|
|
|
+
|
|
|
+ <!-- 获取功能权限 -->
|
|
|
+ <select id="getRoleFun" resultType="java.util.Map">
|
|
|
+ SELECT menu.menu_uuid AS "menuUuid",
|
|
|
+ menu.menu_uuid AS "id",
|
|
|
+ menu.menu_name AS "menuName",
|
|
|
+ menu.app_code AS "appCode",
|
|
|
+ menu.parent_uuid AS "parentId",
|
|
|
+ menu.flg_menu AS "flgMenu",
|
|
|
+ roleFun.role_id AS "roleId",
|
|
|
+ menu.fun_uuid AS "funUuid",
|
|
|
+ CASE
|
|
|
+ WHEN roleFun.role_id IS NULL THEN FALSE
|
|
|
+ ELSE TRUE END AS "checked",
|
|
|
+ (
|
|
|
+ SELECT json_agg(jsonb_build_object('menuUuid', sub_menu.menu_uuid,
|
|
|
+ 'id', sub_menu.menu_uuid,
|
|
|
+ 'menuName', sub_menu.menu_name,
|
|
|
+ 'appCode', sub_menu.app_code,
|
|
|
+ 'parentId', sub_menu.parent_uuid,
|
|
|
+ 'flgMenu', sub_menu.flg_menu,
|
|
|
+ 'roleId', rf.role_id,
|
|
|
+ 'funUuid', sub_menu.fun_uuid,
|
|
|
+ 'checked', CASE
|
|
|
+ WHEN rf.role_id IS NULL THEN FALSE
|
|
|
+ ELSE TRUE END))
|
|
|
+ FROM sys.t_app_menu sub_menu
|
|
|
+ LEFT JOIN dkic_b.t_mst_role_fun rf ON sub_menu.fun_uuid = rf.fun_uuid and rf.role_id = #{roleId}::uuid
|
|
|
+ WHERE sub_menu.parent_uuid = menu.menu_uuid AND menu.menu_type = 0
|
|
|
+ ) AS "subMenus"
|
|
|
+ FROM sys.t_app_menu menu
|
|
|
+ LEFT JOIN dkic_b.t_mst_role_fun roleFun ON menu.fun_uuid = roleFun.fun_uuid and roleFun.role_id = #{roleId}::uuid
|
|
|
+ WHERE menu.flg_valid
|
|
|
+ AND menu.menu_type = 0
|
|
|
+ AND menu.flg_right
|
|
|
+ AND menu.object_code != 'home'
|
|
|
+ ORDER BY menu.level_code;
|
|
|
+ </select>
|
|
|
+
|
|
|
+
|
|
|
+ <!-- 根据主键查询表t_mst_role_fun的一行数据 -->
|
|
|
+ <select id="selectById" resultMap="BaseResultMap">
|
|
|
+ SELECT
|
|
|
+ <include refid="Base_Column_List"/>
|
|
|
+ FROM dkic_b.t_mst_role_fun
|
|
|
+ WHERE role_id = #{roleId}::uuid
|
|
|
+ </select>
|
|
|
+
|
|
|
+ <!-- 根据主键锁定表t_mst_role_fun的一行数据 -->
|
|
|
+ <select id="selectByIdForUpdate" resultMap="BaseResultMap">
|
|
|
+ SELECT
|
|
|
+ <include refid="Base_Column_List"/>
|
|
|
+ FROM dkic_b.t_mst_role_fun
|
|
|
+ WHERE role_id = #{roleId}
|
|
|
+ for update
|
|
|
+ </select>
|
|
|
+
|
|
|
+ <!-- 根据主键锁定表t_mst_role_fun的多行数据 -->
|
|
|
+ <select id="selectByIdsForUpdate" resultMap="BaseResultMap">
|
|
|
+ SELECT
|
|
|
+ <include refid="Base_Column_List"/>
|
|
|
+ FROM dkic_b.t_mst_role_fun
|
|
|
+ <include refid="idsForeach"/>
|
|
|
+ for update
|
|
|
+ </select>
|
|
|
+
|
|
|
+ <insert id="insertBatch">
|
|
|
+ insert into dkic_b.t_mst_role_fun
|
|
|
+ (
|
|
|
+ <trim suffixOverrides=",">
|
|
|
+ role_id,
|
|
|
+ fun_uuid,
|
|
|
+ app_code,
|
|
|
+ cp_id,
|
|
|
+ op_app_code,
|
|
|
+ </trim>
|
|
|
+ )
|
|
|
+ values
|
|
|
+ <foreach collection="list" index="index" item="item" separator=",">
|
|
|
+ (
|
|
|
+ <trim suffixOverrides=",">
|
|
|
+ #{item.roleId}::uuid,
|
|
|
+ #{item.funUuid}::uuid,
|
|
|
+ #{item.appCode},
|
|
|
+ #{item.cpId},
|
|
|
+ #{item.opAppCode},
|
|
|
+ </trim>
|
|
|
+ )
|
|
|
+ </foreach>
|
|
|
+ </insert>
|
|
|
+</mapper>
|