169 lines
6.3 KiB
Transact-SQL
169 lines
6.3 KiB
Transact-SQL
-- =============================================
|
||
-- 中奖公告管理菜单初始化脚本
|
||
-- 用于在后台管理系统中添加中奖公告管理菜单
|
||
--
|
||
-- 注意:此脚本需要在 Admin 数据库 (honey_box_admin) 中执行
|
||
-- 表名使用小写(menus, roles, permissions, role_menus, role_permissions)
|
||
-- =============================================
|
||
|
||
-- 注意:执行此脚本前请确保:
|
||
-- 1. 已存在超级管理员角色 (Code = 'super_admin')
|
||
-- 2. 数据库中已有基础菜单数据
|
||
-- 3. 已存在内容管理目录菜单
|
||
|
||
-- 声明变量
|
||
DECLARE @ContentMenuId BIGINT;
|
||
DECLARE @SuperAdminRoleId BIGINT;
|
||
DECLARE @AnnouncementMenuId BIGINT;
|
||
|
||
-- 获取超级管理员角色ID
|
||
SELECT @SuperAdminRoleId = Id FROM roles WHERE Code = 'super_admin';
|
||
|
||
-- 获取内容管理目录ID
|
||
SELECT @ContentMenuId = Id FROM menus WHERE Path = '/business/content';
|
||
|
||
-- 如果内容管理目录不存在,则创建它
|
||
IF @ContentMenuId IS NULL
|
||
BEGIN
|
||
INSERT INTO menus (ParentId, Name, Path, Component, Icon, MenuType, Permission, SortOrder, Status, IsExternal, IsCache, CreatedAt)
|
||
VALUES (0, N'内容管理', '/business/content', 'Layout', 'Document', 1, NULL, 70, 1, 0, 0, GETDATE());
|
||
|
||
SET @ContentMenuId = SCOPE_IDENTITY();
|
||
PRINT N'创建内容管理目录,ID: ' + CAST(@ContentMenuId AS VARCHAR);
|
||
END
|
||
ELSE
|
||
BEGIN
|
||
PRINT N'内容管理目录已存在,ID: ' + CAST(@ContentMenuId AS VARCHAR);
|
||
END
|
||
|
||
-- =============================================
|
||
-- 1. 创建中奖公告管理菜单
|
||
-- =============================================
|
||
IF NOT EXISTS (SELECT 1 FROM menus WHERE Path = '/business/announcement/list')
|
||
BEGIN
|
||
INSERT INTO menus (ParentId, Name, Path, Component, Icon, MenuType, Permission, SortOrder, Status, IsExternal, IsCache, CreatedAt)
|
||
VALUES (@ContentMenuId, N'中奖公告管理', '/business/announcement/list', 'business/announcement/index', 'Bell', 2, 'announcement:list', 4, 1, 0, 1, GETDATE());
|
||
|
||
SET @AnnouncementMenuId = SCOPE_IDENTITY();
|
||
PRINT N'创建中奖公告管理菜单,ID: ' + CAST(@AnnouncementMenuId AS VARCHAR);
|
||
END
|
||
ELSE
|
||
BEGIN
|
||
SELECT @AnnouncementMenuId = Id FROM menus WHERE Path = '/business/announcement/list';
|
||
PRINT N'中奖公告管理菜单已存在,ID: ' + CAST(@AnnouncementMenuId AS VARCHAR);
|
||
END
|
||
|
||
-- =============================================
|
||
-- 2. 添加中奖公告管理相关权限
|
||
-- =============================================
|
||
|
||
IF NOT EXISTS (SELECT 1 FROM permissions WHERE Code = 'announcement:list')
|
||
INSERT INTO permissions (Name, Code, Module, CreatedAt) VALUES (N'公告列表', 'announcement:list', N'内容管理', GETDATE());
|
||
IF NOT EXISTS (SELECT 1 FROM permissions WHERE Code = 'announcement:add')
|
||
INSERT INTO permissions (Name, Code, Module, CreatedAt) VALUES (N'新增公告', 'announcement:add', N'内容管理', GETDATE());
|
||
IF NOT EXISTS (SELECT 1 FROM permissions WHERE Code = 'announcement:edit')
|
||
INSERT INTO permissions (Name, Code, Module, CreatedAt) VALUES (N'编辑公告', 'announcement:edit', N'内容管理', GETDATE());
|
||
IF NOT EXISTS (SELECT 1 FROM permissions WHERE Code = 'announcement:delete')
|
||
INSERT INTO permissions (Name, Code, Module, CreatedAt) VALUES (N'删除公告', 'announcement:delete', N'内容管理', GETDATE());
|
||
IF NOT EXISTS (SELECT 1 FROM permissions WHERE Code = 'announcement:status')
|
||
INSERT INTO permissions (Name, Code, Module, CreatedAt) VALUES (N'切换公告状态', 'announcement:status', N'内容管理', GETDATE());
|
||
|
||
PRINT N'中奖公告管理权限创建完成';
|
||
|
||
-- =============================================
|
||
-- 3. 为超级管理员角色分配新菜单和权限
|
||
-- =============================================
|
||
IF @SuperAdminRoleId IS NOT NULL
|
||
BEGIN
|
||
-- 分配内容管理目录(如果尚未分配)
|
||
IF NOT EXISTS (SELECT 1 FROM role_menus WHERE RoleId = @SuperAdminRoleId AND MenuId = @ContentMenuId)
|
||
BEGIN
|
||
INSERT INTO role_menus (RoleId, MenuId) VALUES (@SuperAdminRoleId, @ContentMenuId);
|
||
PRINT N'为超级管理员分配内容管理目录';
|
||
END
|
||
|
||
-- 分配中奖公告管理菜单
|
||
IF @AnnouncementMenuId IS NOT NULL AND NOT EXISTS (SELECT 1 FROM role_menus WHERE RoleId = @SuperAdminRoleId AND MenuId = @AnnouncementMenuId)
|
||
BEGIN
|
||
INSERT INTO role_menus (RoleId, MenuId) VALUES (@SuperAdminRoleId, @AnnouncementMenuId);
|
||
PRINT N'为超级管理员分配中奖公告管理菜单';
|
||
END
|
||
|
||
-- 分配新增的权限
|
||
INSERT INTO role_permissions (RoleId, PermissionId)
|
||
SELECT @SuperAdminRoleId, p.Id
|
||
FROM permissions p
|
||
WHERE p.Code IN (
|
||
'announcement:list', 'announcement:add', 'announcement:edit',
|
||
'announcement:delete', 'announcement:status'
|
||
)
|
||
AND NOT EXISTS (
|
||
SELECT 1 FROM role_permissions rp
|
||
WHERE rp.RoleId = @SuperAdminRoleId AND rp.PermissionId = p.Id
|
||
);
|
||
|
||
PRINT N'为超级管理员分配中奖公告管理权限';
|
||
END
|
||
ELSE
|
||
BEGIN
|
||
PRINT N'警告:未找到超级管理员角色,请手动分配菜单和权限';
|
||
END
|
||
|
||
-- =============================================
|
||
-- 4. 验证结果
|
||
-- =============================================
|
||
PRINT N'';
|
||
PRINT N'========== 菜单创建结果 ==========';
|
||
SELECT
|
||
m.Id,
|
||
m.ParentId,
|
||
m.Name,
|
||
m.Path,
|
||
m.Component,
|
||
m.MenuType,
|
||
m.Permission,
|
||
m.SortOrder
|
||
FROM menus m
|
||
WHERE m.Path LIKE '/business/announcement%'
|
||
OR m.Path = '/business/content'
|
||
ORDER BY m.ParentId, m.SortOrder;
|
||
|
||
PRINT N'';
|
||
PRINT N'========== 权限创建结果 ==========';
|
||
SELECT
|
||
p.Id,
|
||
p.Name,
|
||
p.Code,
|
||
p.Module
|
||
FROM permissions p
|
||
WHERE p.Code LIKE 'announcement:%'
|
||
ORDER BY p.Code;
|
||
|
||
PRINT N'';
|
||
PRINT N'========== 角色菜单分配结果 ==========';
|
||
SELECT
|
||
r.Name AS RoleName,
|
||
m.Name AS MenuName,
|
||
m.Path
|
||
FROM role_menus rm
|
||
INNER JOIN roles r ON rm.RoleId = r.Id
|
||
INNER JOIN menus m ON rm.MenuId = m.Id
|
||
WHERE m.Path LIKE '/business/announcement%'
|
||
OR m.Path = '/business/content'
|
||
ORDER BY r.Name, m.Path;
|
||
|
||
PRINT N'';
|
||
PRINT N'========== 角色权限分配结果 ==========';
|
||
SELECT
|
||
r.Name AS RoleName,
|
||
p.Name AS PermissionName,
|
||
p.Code
|
||
FROM role_permissions rp
|
||
INNER JOIN roles r ON rp.RoleId = r.Id
|
||
INNER JOIN permissions p ON rp.PermissionId = p.Id
|
||
WHERE p.Code LIKE 'announcement:%'
|
||
ORDER BY r.Name, p.Code;
|
||
|
||
PRINT N'';
|
||
PRINT N'中奖公告管理菜单初始化完成';
|