Files
his/迁移记录-DB变更记录/find_and_fix_duplicate_path.sql
chenqi 0c35044231 feat(menu): 优化菜单路径唯一性校验并更新前端界面
- 在SysLoginController中添加optionMap数据返回
- 添加JSQLParser依赖支持MyBatis Plus功能
- 实现selectMenuByPathExcludeId方法用于排除当前菜单的路径唯一性校验
- 在SysMenuServiceImpl中添加日志记录并优化路径唯一性判断逻辑
- 在SysMenuMapper.xml中添加LIMIT 1限制并实现排除ID查询
- 在前端路由中注释患者管理相关路由配置
- 在用户store中添加optionMap配置项并优先从optionMap获取医院名称
- 重构检查项目设置页面的操作按钮样式为统一的圆形按钮设计
- 更新检查项目设置页面的导航栏样式和交互体验
- 优化门诊记录页面的搜索条件和表格展示功能
- 添加性别和状态筛选条件并改进数据加载逻辑
2026-01-03 23:47:09 +08:00

38 lines
1.0 KiB
SQL

-- =====================================================
-- 查找并修复 sys_menu 表中重复的 path 记录
-- PostgreSQL 版本
-- =====================================================
-- 第一步:查看是否有重复的 path
SELECT
path,
COUNT(*) as count,
STRING_AGG(CAST(menu_id AS TEXT), ', ') as menu_ids,
STRING_AGG(menu_name, ', ') as menu_names
FROM sys_menu
GROUP BY path
HAVING COUNT(*) > 1;
-- 第二步:查看具体重复记录的详细信息
-- (替换下面的重复路径值)
-- SELECT * FROM sys_menu WHERE path = 'your_duplicate_path_value' ORDER BY menu_id;
-- 第三步:自动删除重复的 path 记录(保留 menu_id 最小的)
DELETE FROM sys_menu
WHERE menu_id IN (
SELECT menu_id FROM (
SELECT menu_id,
ROW_NUMBER() OVER (PARTITION BY path ORDER BY menu_id) as rn
FROM sys_menu
) t
WHERE rn > 1
);
-- 第四步:验证是否还有重复的 path
SELECT
path,
COUNT(*) as count
FROM sys_menu
GROUP BY path
HAVING COUNT(*) > 1;