下面是我常用的一种左联查询方式,实例为两表联查,使用内联也可以做到3表4表联查等等
SELECT comment.id,comment.blog_id,comment.commenter_id,comment.content,comment.parent_id,comment.time,userid.userhead,userid.nickname,userid.useremail
FROM
comment left join userid on comment.commenter_id = userid.id WHERE comment.blog_id
LIKE
"f6dba3ddb97211edbeb5003e690bad7a"
ORDER BY `comment`.`time` ASC
MySQL联合查询效率较高,以下例子来说明联合查询(内联、左联、右联、全联)的好处:
T1表结构(用户id,用户名,密码)
userid | username | password |
---|---|---|
1 | jack | jackpwd |
2 | owen | owenpwd |
T2表结构(用户id,用户积分,用户等级)
userid | jifen | dengji |
---|---|---|
1 | 20 | 3 |
3 | 50 | 6 |
如果想把用户信息、积分、等级都列出来,那么一般会这样写:
select * from T1 inner join T3 on T1.userid=T3.userid
SQL语句:
select * from **T1** inner join **T2** on **T1.userid** = **T2.userid**
运行结果
userid | username | password | userid | jifen | dengji |
---|---|---|---|---|---|
1 | jack | jackpwd | 1 | 20 | 3 |
显示左表T1中的所有行,并把右表T2中符合条件加到左表T1中; 右表T2中不符合条件,就不用加入结果表中,并且NULL表示。
SQL语句:
select * from T1 left join T2 on T1.userid = T2.userid
运行结果
userid | username | password | userid | jifen | dengji |
---|---|---|---|---|---|
1 | jack | ackpwd | 1 | 20 | 3 |
2 | owen | owenpwd | NULL | NULL | NULL |
显示右表T2中的所有行,并把左表T1中符合条件加到右表T2中; 左表T1中不符合条件,就不用加入结果表中,并且NULL表示。
SQL语句:
select * from T1 right join T2 on T1.userid = T2.userid
运行结果
userid | username | password | userid | jifen | dengji |
---|---|---|---|---|---|
1 | jack | jackpwd | 1 | 20 | 3 |
NULL | NULL | NULL | 3 | 50 | 6 |
显示左表T1、右表T2两边中的所有行,即把左联结果表 + 右联结果表组合在一起,然后过滤掉重复的。
SQL语句:
select * from T1 full join T2 on T1.userid = T2.userid
运行结果
userid | username | password | userid | jifen | dengji |
---|---|---|---|---|---|
1 | jack | jackpwd | 1 | 2 | 3 |
NULL | NULL | NULL | 3 | 50 | 6 |
总结,关于联合查询,效率的确比较高,4种联合方式如果可以灵活使用,基本上复杂的语句结构也会简单起来。