####表 a aid|name|cid|did|sex|xdate --|:--:|:--:|:--:|:--:|--: 1|john|1,3|1,2,3|未知|2021-01-02
####表 c cid|cname --|--: 1|小花 2|阿狸 3|大菊
####表 d did|dname --|--: 1|大黄 2|小黑 3|小灰
需要一次性查出表 a aid=1 的详细数据,表 a 的 cid 对应表 c 的 cid,表 a 的 did 对应表 d 的 did
![]() | 1 frozenway OP ``` SELECT a.*, c.*, d.* FROM a LEFT JOIN c ON c.cid IN a.cid LEFT JOIN d ON d.did IN a.did WHERE a.aid=1 ``` 这是我想到的语句,但是报错了 |
2 hulalalla 2021-04-01 16:45:46 +08:00 FIND_IN_SET |
![]() | 3 eason1874 2021-04-01 16:51:42 +08:00 LEFT JOIN c ON FIND_IN_SET(c.cid, a.cid) |
![]() | 4 c6h6benzene 2021-04-01 16:52:18 +08:00 via iPhone 这表设计就…一言难尽。 IN 的运算对象是集合,你需要想办法把 a 表中的 cid 和 did 拆开,例如 SQL Server 的 STRING_SPLIT 。 |
![]() | 5 urlk 2021-04-01 16:55:48 +08:00 建议分开查 ... , 联表查出来格式也不对 |
![]() | 6 lance6716 2021-04-01 16:58:18 +08:00 ![]() 第一次见第一范式都不符合的…… |
![]() | 7 x86 2021-04-01 16:59:33 +08:00 这 MySQL 表跟受委屈了... |
8 yeqizhang 2021-04-01 16:59:43 +08:00 分开查没毛病, 如果是管理系统的列表展示, 循环多查几次而已。 这不会是面试题吧? |
9 customsshen 2021-04-01 17:01:44 +08:00 via Android select a.*,c.* from a left join c on a.cid= c.cid where a.aid=1 union ( select a.* , d.* from a left join d on a.cid= d.cid where a.aid=1 ) |
10 yeqizhang 2021-04-01 17:09:53 +08:00 @customsshen 兄弟,你看错了,a.cid 是逗号分隔的多个 id |
11 customsshen 2021-04-01 17:20:30 +08:00 via Android @yeqizhang 哈哈,好家伙,直接放弃吧。 |
12 dqzcwxb 2021-04-01 17:34:10 +08:00 ![]() 放一条 sql 查恰恰是效率最低的方案之一 |
![]() | 13 shyrock 2021-04-01 18:20:06 +08:00 拒绝回答这种问题,建议赶紧把表 1 拆开。把设计这种表的人拉去挂电线杆。 |
14 pendulum 2021-04-01 19:17:00 +08:00 表 a 的设计真是。。 |
![]() | 15 TomVista 2021-04-01 19:42:14 +08:00 祭天吧 |
16 tcfenix 2021-04-01 19:49:02 +08:00 如果你想 cid 跟 did 用来做外键的话你就应该搞个 relation 表, 建立 aid cid 与 did 的多对多对多的关系 到时候用起来就很简单 而不是用逗号分隔.....你这设计的都能进教科书了..... |
![]() | 17 KouShuiYu 2021-04-01 22:25:08 +08:00 postgresql 是支持的,可以吧 cid,did 转成数组关联查询, |
![]() | 18 vynkicc 2021-04-02 11:03:42 +08:00 解决开表 1 的人 |
![]() | 19 AlkTTT 2021-04-02 11:27:45 +08:00 这 A 表降 san 值,快跑! |
![]() | 20 SjwNo1 2021-04-02 19:53:56 +08:00 via iPhone 为啥要一条 sql |