Files
bl/help/base_sys_user_role去重.sql

46 lines
1.3 KiB
Go
Raw Normal View History

-- base_sys_user_role 角色授权去重
2026-04-27 00:51:28 +08:00
-- 只处理未软删除的有效授权软删除历史记录不参与去重和唯一约束
-- 保留每组有效 userId + roleId id 最小的一条删除其余重复记录
-- 1. 执行前查看重复数据
SELECT
"userId",
"roleId",
COUNT(*) AS cnt,
MIN(id) AS keep_id,
ARRAY_AGG(id ORDER BY id) AS ids
FROM base_sys_user_role
2026-04-27 00:51:28 +08:00
WHERE deleted_at IS NULL
GROUP BY "userId", "roleId"
HAVING COUNT(*) > 1
ORDER BY cnt DESC, "userId", "roleId";
-- 2. 删除重复数据
DELETE FROM base_sys_user_role a
USING base_sys_user_role b
WHERE a."userId" = b."userId"
AND a."roleId" = b."roleId"
2026-04-27 00:51:28 +08:00
AND a.deleted_at IS NULL
AND b.deleted_at IS NULL
AND a.id > b.id;
-- 3. 执行后复查应返回 0
SELECT
"userId",
"roleId",
COUNT(*) AS cnt
FROM base_sys_user_role
2026-04-27 00:51:28 +08:00
WHERE deleted_at IS NULL
GROUP BY "userId", "roleId"
HAVING COUNT(*) > 1;
2026-04-27 00:51:28 +08:00
-- 4. 建议约束只限制未软删除授权唯一允许历史软删除授权保留
ALTER TABLE base_sys_user_role
DROP CONSTRAINT IF EXISTS uk_base_sys_user_role_user_role;
DROP INDEX IF EXISTS uk_base_sys_user_role_user_role;
CREATE UNIQUE INDEX IF NOT EXISTS uk_base_sys_user_role_user_role
ON base_sys_user_role ("userId", "roleId")
WHERE deleted_at IS NULL;