mysql關聯查詢去重 MySQL 關聯查詢

2021-10-14 05:46:54 字數 2106 閱讀 8778

mysql-關聯查詢

sql資料分析 1週前

mysql

關聯查詢

前面,我們介紹的都是單錶查詢(就是只從一張表中獲取資料),而實際應用的時候,我們都會同時查詢多張表,這裡,我們就介紹下,多表關聯查詢的使用。

sql join 用於根據兩個或多個表中的列之間的關係,從這些表中查詢資料

前置知識

主鍵(primary key):可以唯一確定一條記錄的字段,比如學生表中的學生id,生活中我們的身份證號

外來鍵(foreign key):指向另一張表的主鍵,比如學生表中的班級id,班級id是班級表中的主鍵,但在學生表中是外來鍵

主鍵和外來鍵可以在建表的時候指定,他可以在資料庫層面,控制你的資料的完整性、一致性。

測試資料參考:inner join

inner join 可以簡寫為 join,結果集是兩張表中都存在的記錄,是乙個交集,詳情參考上面的。

比如:在學生表中,有乙個班級id,我們想根據班級id,在班級表中找到班級資訊

select

*from

t_student a

-- 要關聯查詢的表

join

t_class b

-- 使用什麼欄位去關聯這兩張表

左關聯,以左邊的表為主表,不管外來鍵在右表中是否存在,左表的資料都會存在。

比如學生表中,有這樣一條記錄,他的班級id是904,但是班級表中並沒有904的班級資訊,

所以,使用join的話是查不到這條記錄的

-- 2. left join

-- 學生表為主表,包含所有學生資訊

右關聯,和做關聯類似,但已右表為主表

-- 3. right join

-- 班級表為主表,不管改班級是否有學生資訊

全關聯,mysql沒有full join 語法,我們可以通過使用union來實現

cross join 是對2個表做笛卡爾積

select *from t_class a

cross join t_class b

order by a.c_id,b.c_id

;小結

關聯查詢的話,我們主要是選擇好主表,然後找好表與表之間的關聯關係,注意多對多、一對多的這種關係,驗證號結果資料就行了。

mysql關聯查詢

在程式開發時,不可避免的要用到檢視,首先我們來看看檢視到底有什麼作用 簡單性 看到的就是需要的。檢視不僅可以簡化使用者對資料的理解,也可以簡化他們的操作。那些被經常使用的查詢可以被定義為檢視,從而使得使用者不必為以後的操作每次制定全部的條件。安全性 通過檢視用固話只能查詢和修改他們所能見到的資料。資...

Mysql關聯查詢

七種結果 7 a b a b 或者 a a b b a b 如何實現?1 內連線 2 外連線 左外連線 右外連線 全外連線 mysql使用union代替全外連線 1.內連線 實現a b select 字段列表 from a表 inner join b表 on 關聯條件 where 等其他子句 或se...

mysql 關聯查詢

inner join 只取兩張表的交集的部分,join預設為inner join left join 取左表的所有部分,並且取出與右表關聯上的資料 同left join的作用,只是驅動錶換了位置 全外連線,mysql目前沒有,可以用union代替,如 select e.empname,d.deptn...