資料庫多連表
1. ACCESS資料庫中如何實現多表聯合查詢
1、Access 資料庫多表聯合查詢,每次連接之前須將連接符前面的內容放在括弧裡面,示例如:select 表a.欄位1,表b.欄位1,表c.欄位1,表d.欄位1 from ((表a inner join 表b on 表a.欄位=表b.欄位) inner join 表c on 表c.欄位=表a.欄位)inner join 表d on 表a.欄位=表d.欄位
2、如果每個聯合欄位不止一個可將on後面條件加(),如:select 表a.欄位1,表b.欄位1,表c.欄位1,表d.欄位1 from (表a inner join 表b on (表a.欄位1=表b.欄位1 and 表a.欄位2=表b.欄位2)) inner join 表c on 表c.欄位=表a.欄位
3、如果要一次聯合一個表多次,但條件不同,可以每次連接此表時給此表換個別名,用別名操作即可,如:select aa.欄位1,表b.欄位1,表c.欄位1,bb.欄位2 from ((表a as aa inner join 表b on aa.欄位1=表b.欄位) inner join 表c on 表c.欄位=表a.欄位)inner join 表a as bb on 表a.欄位=bb.欄位2.
2. 資料庫中多表連接的原理實現
多變關聯的實現方式有hash join,merge join,nested loop join 方式,具體使用那種內型的連接,主要依據:
1.當前的優化器模式(all_rows和rule)
2.取決於表的大小
3.取決於關聯欄位是否有索性
4.取決於關聯欄位是否排序
Hash join散列連接,優化器選擇較小的表(數據量少的表)利用連接鍵(join key)在內存中建立散列表,將數據存儲到hash列表中,然後掃描較大的表
select A.*,B.* from A left join B on a.id=b.id。
先是從A表讀取一條記錄,用on條件匹配B表的記錄,行成n行(包括重復行)如果B表沒有與匹配的數據,則select中B表的欄位顯示為空,接著讀取A表的下一條記錄,right join類似。
left join基本是A表全部掃描,在表關鍵中不建議使用子查詢作為副表,比如select A.*,B.*from A left join (select * from b where b.type=1 )這樣A表是全表掃描,B表也是全表掃描。若果查詢慢,可以考慮關聯的欄位都建索引,將不必要的排序去掉,排序會導致運行慢很多。
主副表條件過濾:
table a(id, type):
id type
----------------------------------
1 1
2 1
3 2
表b結構和數據
table b(id, class):
id class
---------------------------------
1 1
2 2
sql語句1: select a.*, b.* from a left join b on a.id = b.id and a.type = 1;
執行結果為:
a.id a.type b.id b.class
----------------------------------------
1 1 1 1
2 1 2 2
3 2
a.type=1沒有起作用
sql語句2:
select a.*, b.* from a left join b on a.id = b.id where a.type = 1;
執行結果為:
a.id a.type b.id b.class
----------------------------------------
1 1 1 1
2 1 2 2
sql語句3:
select a.*, b.* from a left join b on a.id = b.id and b.class = 1;
執行結果為:
a.id a.type b.id b.class
----------------------------------------
1 1 1 1
2 1
3 2
b.class=1條件過濾成功。
結論:left join中,左表(主表)的過濾條件在on後不起作用,需要在where中添加。右表(副表)的過濾條件在on後面起作用。
Mysql join原理:
Mysql join採用了Nested Loop join的演算法,
###坐車 回去補充。
3. 關系資料庫如何查詢多表有聯系數據
關聯查詢是日常工作中常用的查詢方式,關聯查詢sql編寫的思路一般如下:1、先確定所連接的表,2、再確定所要查詢的欄位,3、確定連接條件以及連接方式(表連接分類: 內連接、外連接、交叉連接、自連接)
1、內連接:[inner] join on
分類:等值連接、非等值連接
(1)等值連接: 指使用等號"=「比較兩個表的連接列的值,相當於兩表執行笛卡爾後,取兩表連結列值相等的記錄(自然連接是一種特殊的等值連接)(2)非等值連接:指使用」>「或」<"比較兩個表的連接列的值,相當於兩表執行笛卡爾後,取一個表大於或小於另一個表的連結列值的記錄
2、外連接
分類:左外連接、右外連接、全外連接
(1)左外連接:left outer join
連接效果:查詢結果包含左、右兩個表需要查詢的全部行,左側的表中的全部數據都會被顯示出來,但是右側表的數據,只有和左側匹配上的數據才會被查詢出來!否則顯示為null(2)右外連接:right outer join
連接效果:查詢結果包含左、右兩個表需要查詢的全部行,右側的表中的全部數據都會被顯示出來,但是左側表的數據,只有和右側匹配上的數據才會被查詢出來!否則顯示為null(3)全外連接:full/all outer join,查詢結果包含左、右兩個表需要查詢的全部行,對應欄位沒有值顯示null
3、交叉連接
左表中的每一行與右表中的所有行組合,也叫表與表之間做笛卡爾積查詢
4、自連接
當前表與自身的連接查詢,關鍵點在於虛擬化出一張表,即給自身的表定義一個別名
4. SQL server資料庫中的多表連接查詢和子查詢的區別
連接查詢是
通過主外鍵
讓多個表數據對應
成一個表數據,而子查詢是查到的數據
利用這個數據再查別的
如查張三的年級ID
再用這個年級ID去查對應的年級名