SQL JOIN的用法
背景:(血的教訓)
非常感謝能夠有幸的去活力世紀面試,面試官非常的祥和,雖然最后沒能夠去成,但是非常的感謝,是他讓我明白了自己還有很多需要去學習,每一次的面試不是為了去證明自己有多強,能拿多少的工資,而是去檢驗自己哪些方面還有不足,需要去努力,加油,為了更好的自己......之前在公司的代碼中看到了關于一些left join的東西,但是沒有太關注這些,剛好面試的時候問到了這些,現在剛好有時間,順便的學習一遍,加強自己.......
關于sql語句中的連接(join)關鍵字,是較為常用而又不太容易理解的關鍵字,廢話就不多說了,直接進入主題,案例:
可以參照博客:http://www.cnblogs.com/yiki/archive/2007/01/04/611452.html
一、建表
新建表一 table1 ? ? ? ? ? ?新建表二 ?table2
? ? ? ? ??
一、外連接
1.概念:包括左向外聯接、右向外聯接或完整外部聯接
2.左連接:left join 或 left outer join
(1)左向外聯接的結果集包括 LEFT OUTER 子句中指定的左表的所有行,而不僅僅是聯接列所匹配的行。如果左表的某行在右表中沒有匹配行,則在相關聯的結果集行中右表的所有選擇列表列均為空值(null)。
(2)sql語句
-------------結果-------------
?注釋:包含table1的所有子句,根據指定條件返回table2相應的字段,不符合的以null顯示 ?不可以使用where作為條件的篩選噢,不然會報錯的
3.右連接:right join 或 right outer join
(1)右向外聯接是左向外聯接的反向聯接。將返回右表的所有行。如果右表的某行在左表中沒有匹配行,則將為左表返回空值。
(2)sql語句
-------------結果-------------
?
注釋:包含table2的所有子句,根據指定條件返回table1相應的字段,不符合的以null顯示
4.完整外部聯接:full join 或 full outer join?
(1)完整外部聯接返回左表和右表中的所有行。當某行在另一個表中沒有匹配行時,則另一個表的選擇列表列包含空值。如果表之間有匹配行,則整個結果集行包含基表的數據值。
(2)sql語句
我的數據庫5.5中竟然不支持full join 所以我用了另外一種來代替
select * from table1 left join table2 on table1.id=table2.id UNION select * from table1 RIGHT JOIN table2 on table1.id=table2.id-------------結果-------------
注釋:返回左右連接的和(見上左、右連接)
二、內連接
1.概念:內聯接是用比較運算符比較要聯接列的值的聯接
2.內連接:join 或 inner join
3.sql語句
select * from table1 join table2 on table1.id=table2.id-------------結果-------------
注釋:只返回符合條件的table1和table2的列
4.等價(與下列執行效果相同)
A:select a.*,b.* from table1 a,table2 b where a.id=b.id
B:select * from table1 cross join table2 where table1.id=table2.id? (注:cross join后加條件只能用where,不能用on)
三、交叉連接(完全)
1.概念:沒有 WHERE 子句的交叉聯接將產生聯接所涉及的表的笛卡爾積。第一個表的行數乘以第二個表的行數等于笛卡爾積結果集的大小。(table1和table2交叉連接產生3*3=9條記錄)
2.交叉連接:cross join (不帶條件where...)
3.sql語句
select * from table1 cross join table2-------------結果-------------
注釋:返回3*3=9條記錄,即笛卡爾積
4.等價(與下列執行效果相同)
A:select * from table1,table2 ? ? ?
?
轉載于:https://www.cnblogs.com/antonyhubei/p/5600096.html
總結
以上是生活随笔為你收集整理的SQL JOIN的用法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: FromBottomToTop团队项目总
- 下一篇: linux cmake编译源码,linu