MySQL联合查询语法内联、左联、右联、全联.docx - Word

下面是我常用的一种左联查询方式,实例为两表联查,使用内联也可以做到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

内联(inner join)

如果想把用户信息、积分、等级都列出来,那么一般会这样写:

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

左联(left join)

显示左表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

右联(right join)

显示右表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

全联(full join)

显示左表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种联合方式如果可以灵活使用,基本上复杂的语句结构也会简单起来。

第1页,共1页
本文共0个字符
中文(中国)
辅助功能
文档日期2023-03-07 14:06:09