####表 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
shenjinpeng 2021-04-01 16:55:48 +08:00
建议分开查 ... , 联表查出来格式也不对
|
6
lance6716 2021-04-01 16:58:18 +08:00 1
第一次见第一范式都不符合的……
|
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 1
放一条 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
|