2025-10-07 11:02:35 +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">
|
|
|
|
|
<mapper namespace="org.xyzh.system.mapper.MenuPermissionMapper">
|
|
|
|
|
|
|
|
|
|
<!-- 基础结果映射 -->
|
|
|
|
|
<resultMap id="BaseResultMap" type="org.xyzh.common.dto.menu.TbSysMenuPermission">
|
|
|
|
|
<id column="id" property="id" jdbcType="VARCHAR"/>
|
|
|
|
|
<result column="menu_id" property="menuID" jdbcType="VARCHAR"/>
|
|
|
|
|
<result column="permission_id" property="permissionID" jdbcType="VARCHAR"/>
|
|
|
|
|
<result column="creator" property="creator" jdbcType="VARCHAR"/>
|
|
|
|
|
<result column="updater" property="updater" jdbcType="VARCHAR"/>
|
|
|
|
|
<result column="create_time" property="createTime" jdbcType="TIMESTAMP"/>
|
|
|
|
|
<result column="update_time" property="updateTime" jdbcType="TIMESTAMP"/>
|
|
|
|
|
<result column="delete_time" property="deleteTime" jdbcType="TIMESTAMP"/>
|
|
|
|
|
<result column="deleted" property="deleted" jdbcType="BOOLEAN"/>
|
|
|
|
|
</resultMap>
|
|
|
|
|
|
|
|
|
|
<!-- 基础字段 -->
|
|
|
|
|
<sql id="Base_Column_List">
|
|
|
|
|
id, menu_id, permission_id, creator, updater,
|
|
|
|
|
create_time, update_time, delete_time, deleted
|
|
|
|
|
</sql>
|
|
|
|
|
|
|
|
|
|
<!-- 批量绑定菜单权限 -->
|
|
|
|
|
<insert id="batchBindMenuPermission">
|
|
|
|
|
INSERT INTO tb_sys_menu_permission (id, menu_id, permission_id, creator, create_time, deleted)
|
|
|
|
|
VALUES
|
|
|
|
|
<foreach collection="menuPermissions" item="menuPermission" separator=",">
|
|
|
|
|
(#{menuPermission.id}, #{menuPermission.menuID}, #{menuPermission.permissionID}, #{menuPermission.creator}, #{menuPermission.createTime}, 0)
|
|
|
|
|
</foreach>
|
|
|
|
|
</insert>
|
|
|
|
|
|
|
|
|
|
<!-- 批量解绑菜单权限(真删除) -->
|
|
|
|
|
<delete id="batchUnbindMenuPermission">
|
|
|
|
|
DELETE FROM tb_sys_menu_permission
|
2025-10-09 16:35:49 +08:00
|
|
|
WHERE (menu_id, permission_id) IN
|
2025-10-07 11:02:35 +08:00
|
|
|
<foreach collection="menuPermissions" item="menuPermission" open="(" separator="," close=")">
|
2025-10-09 16:35:49 +08:00
|
|
|
(#{menuPermission.menuID}, #{menuPermission.permissionID})
|
2025-10-07 11:02:35 +08:00
|
|
|
</foreach>
|
|
|
|
|
AND deleted = 0
|
|
|
|
|
</delete>
|
|
|
|
|
|
|
|
|
|
<!-- 根据菜单ID和权限ID查询关联关系 -->
|
|
|
|
|
<select id="selectByMenuIdAndPermissionId" resultMap="BaseResultMap">
|
|
|
|
|
SELECT
|
|
|
|
|
<include refid="Base_Column_List"/>
|
|
|
|
|
FROM tb_sys_menu_permission
|
|
|
|
|
WHERE deleted = 0
|
|
|
|
|
AND menu_id = #{menuId}
|
|
|
|
|
AND permission_id = #{permissionId}
|
|
|
|
|
LIMIT 1
|
|
|
|
|
</select>
|
|
|
|
|
|
|
|
|
|
<!-- 根据菜单ID查询权限关联列表 -->
|
|
|
|
|
<select id="selectByMenuId" resultMap="BaseResultMap">
|
|
|
|
|
SELECT
|
|
|
|
|
<include refid="Base_Column_List"/>
|
|
|
|
|
FROM tb_sys_menu_permission
|
|
|
|
|
WHERE deleted = 0
|
|
|
|
|
AND menu_id = #{menuId}
|
|
|
|
|
ORDER BY create_time ASC
|
|
|
|
|
</select>
|
|
|
|
|
|
|
|
|
|
<!-- 根据权限ID查询菜单关联列表 -->
|
|
|
|
|
<select id="selectByPermissionId" resultMap="BaseResultMap">
|
|
|
|
|
SELECT
|
|
|
|
|
<include refid="Base_Column_List"/>
|
|
|
|
|
FROM tb_sys_menu_permission
|
|
|
|
|
WHERE deleted = 0
|
|
|
|
|
AND permission_id = #{permissionId}
|
|
|
|
|
ORDER BY create_time ASC
|
|
|
|
|
</select>
|
|
|
|
|
|
|
|
|
|
<!-- 删除菜单权限关联(逻辑删除) -->
|
|
|
|
|
<update id="deleteByMenuIdAndPermissionId">
|
|
|
|
|
UPDATE tb_sys_menu_permission
|
|
|
|
|
SET deleted = 1,
|
|
|
|
|
delete_time = NOW(),
|
|
|
|
|
updater = #{updater}
|
|
|
|
|
WHERE deleted = 0
|
|
|
|
|
AND menu_id = #{menuId}
|
|
|
|
|
AND permission_id = #{permissionId}
|
|
|
|
|
</update>
|
|
|
|
|
|
|
|
|
|
</mapper>
|