一个 SQL 联表的弱智问题

2014-06-14 23:21:19 +08:00
 kmvan
messages 表
ID---author---receiver---content
1------1---------2---------你好
2------2---------1---------草泥马

users 表
ID---------name
1----------小明
2----------小花

如何查询才能显示如下结果呢?

ID---content------author------receiver------author_name---receiver_name
1-----你好-----------1-------------2-------------小明------------小花


蛋疼,不怎么擅长sql= =
2761 次点击
所在节点    程序员
12 条回复
catfan
2014-06-14 23:36:04 +08:00
用 JOIN 语法啊
kmvan
2014-06-14 23:38:07 +08:00
我只能查到一个。。。如下,我只能查到作者。。。不能同时查到接收者..
SELECT msg.*, users.name FROM message msg, users
WHERE msg.ID = 1 and msg.author = users.ID
yangqi
2014-06-14 23:39:52 +08:00
SELECT
m.ID,
m.author,
m.receiver,
u1.author_name,
u2.author_name as receiver_name
FROM messages m
LEFT JOIN users u1 ON u1.ID=m.author
LEFT JOIN users u2 ON u2.ID=m.receiver
kmvan
2014-06-14 23:51:34 +08:00
@yangqi 你牛...正解
Seans
2014-06-15 00:08:33 +08:00
@yangqi 帮你调整下:

SELECT
m.ID,
m.content,
m.author,
m.receiver,
u1.name as author_name,
u2.name as receiver_name
FROM messages m
LEFT JOIN users u1 ON u1.ID = m.author
LEFT JOIN users u2 ON u2.ID = m.receiver;

不客气~
ipconfiger
2014-06-15 00:13:15 +08:00
考虑过效率吗,骚年
kmvan
2014-06-15 00:15:49 +08:00
@Seans 3Q
Seans
2014-06-15 00:28:51 +08:00
@ipconfiger 不知道这样写效率会不会高点?

select
n.id,
n.content,
n.author,
n.receiver,
n.name author_name,
u2.name receiver_name
from (select
m.id,
m.author,
m.receiver,
m.content,
u1.name
from messages m, user u1
where m.author = u1.id) n, user u2
where n.receiver = u2.id;
yangqi
2014-06-15 00:39:01 +08:00
@Seans 这样效率反而会低, 括号里面derived table没有索引的
Seans
2014-06-15 01:00:05 +08:00
@yangqi 我不是专业的dba,也不知道该怎样来比较两条sql的效率,是看执行时间吗?只是之前写left join的时候在大表查询的时确实很慢
yangqi
2014-06-15 01:40:30 +08:00
@Seans 最简单的explain下可以看出来, 然后可以用profile来比较.

你第二种写法还是Join, 只不过是inner join, 而且括号中的select会生成一个临时表, 没有索引), 所以效率反而会更低
alore
2014-06-16 16:01:51 +08:00
select *,
(select name from users where id=a.author) as author_name,
(select name from users where id=a.receiver) as receiver_name
from messages as a

效率问题,不用多想.等你上百万数据,上百万流量时再说.

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/117541

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX