不能直接JOIN两张业务表实现多对多,因为user和role表间无外键,强行JOIN会导致笛卡尔积或漏数据;必须通过中间表user_role承载关联,其需含user_id和role_id联合主键,并建对应联合索引以支撑高效查询。为什么不能直接 JOIN 两张业务表实现多对多?因为关系不存在------user 和 role 表之间没有外键,强行 JOIN 会笛卡尔爆炸或漏数据。数据库不支持"一个用户对应多个角色"这种语义直接落在两表字段上,必须靠第三张表承载关联事实。常见错误现象:SELECT * FROM user u JOIN role r ON u.id = r.user_id(r.user_id 根本不存在),或者把 role_ids 存成逗号字符串再用 LIKE 模糊匹配------查不准、索引失效、无法原子更新。中间表(如 user_role)必须有且仅有两个外键:user_id 和 role_id联合主键或唯一索引必不可少,否则同一对关系可能重复插入别在中间表里加业务字段(比如"生效时间"),那是冗余;真有需要,就升级为带属性的关联表,但名字就不再是纯中间表了LEFT JOIN 中间表后怎么避免重复行?用户有 3 个角色,user LEFT JOIN user_role 就会返回 3 行相同用户数据------这不是 bug,是关系代数的自然结果。关键看你要什么:要用户+角色列表,还是用户+角色数量,或是用户+所有角色名拼接。使用场景决定写法:查"每个用户及其所有角色名":用 LEFT JOIN user_role ur ON u.id = ur.user_id + LEFT JOIN role r ON ur.role_id = r.id,接受多行查"每个用户有几个角色":用 COUNT(r.id) + GROUP BY u.id,必须配 GROUP BY,否则聚合结果错乱查"每个用户的角色名合并在一列":用 STRING_AGG(r.name, ', ')(PostgreSQL)或 GROUP_CONCAT(r.name)(MySQL),同样依赖 GROUP BYWHERE 条件写在 ON 还是 WHERE 里?差别极大。中间表参与 LEFT JOIN 时,过滤条件位置直接决定是否丢失"没角色的用户"。 文心快码 文心快码(Comate)是百度推出的一款AI辅助编程工具
相关推荐
用户8356290780511 分钟前
使用 Python 在 PowerPoint 中生成并自定义饼图与环形图棉猴4 分钟前
python海龟绘图之倾转van久27 分钟前
Day32:项目性能优化(EF Core + 分页 + 全异步)小白学大数据34 分钟前
基于大模型的Python智能爬虫:语义识别与数据清洗实践Cloud_Shy61836 分钟前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(附录 B 高级 VS Code 功能)进击切图仔41 分钟前
从零手写 RAGDxy12393102161 小时前
Python请求方式介绍:JSON、表单及其他常见数据传输格式西洼工作室1 小时前
个人开发者接入阿里云号码认证服务AliCloud-NirvanaPns实现一键登录半城抹茶1 小时前
TradingAgents-CN 项目目录文档光影6271 小时前
Selenium自动化测试---实战踩坑实录