91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL中怎么實現關聯查詢

發布時間:2021-07-13 15:27:07 來源:億速云 閱讀:450 作者:Leah 欄目:大數據

這篇文章將為大家詳細講解有關MySQL中怎么實現關聯查詢,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

MySQL
關聯查詢

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

SQL join 用于根據兩個或多個表中的列之間的關系,從這些表中查詢數據

MySQL中怎么實現關聯查詢

前置知識

主鍵(Primary Key):可以唯一確定一條記錄的字段,比如學生表中的學生ID,生活中我們的身份證號
外鍵(Foreign Key):指向另一張表的主鍵,比如學生表中的班級ID,班級ID是班級表中的主鍵,但在學生表中是外鍵

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

測試數據參考:http://yuguiyang.github.io/2017/09/09/mysql-handbook-01/

inner join

inner join 可以簡寫為 join,結果集是兩張表中 都存在的記錄,是一個交集,詳情參考上面的圖片。
比如:在學生表中,有一個班級ID,我們想根據班級ID,在班級表中找到班級信息

select 
    *
from 
    t_student a 
-- 要關聯查詢的表
join 
    t_class b 
-- 使用什么字段去關聯這兩張表
on 
    a.c_id = b.c_id
;

MySQL中怎么實現關聯查詢

left join

左關聯,以左邊的表為主表,不管外鍵在右表中是否存在,左表的數據都會存在。
比如學生表中,有這樣一條記錄,他的班級ID是904,但是班級表中并沒有904的班級信息,
所以,使用join的話是查不到這條記錄的

-- 2. left join 
-- 學生表為主表,包含所有學生信息
select 
    *
from 
    t_student a 
left join 
    t_class b 
on 
    a.c_id = b.c_id
;

MySQL中怎么實現關聯查詢

right join

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

-- 3. right join 
-- 班級表為主表,不管改班級是否有學生信息
select 
    *
from 
    t_student a 
right join 
    t_class b 
on 
    a.c_id = b.c_id
;

MySQL中怎么實現關聯查詢

full outer join

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

select 
    *
from 
    t_student a 
left join 
    t_class b 
on 
    a.c_id = b.c_id
UNION
select 
    *
from 
    t_student a 
right join 
    t_class b 
on 
    a.c_id = b.c_id
;

MySQL中怎么實現關聯查詢

cross join

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

select *from t_class a 
cross join t_class b 
order by a.c_id,b.c_id
;

關于MySQL中怎么實現關聯查詢就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黄龙县| 乐平市| 美姑县| 汉沽区| 五华县| 嘉定区| 舒兰市| 历史| 壤塘县| 始兴县| 石狮市| 休宁县| 塔城市| 江山市| 礼泉县| 大连市| 吴江市| 那坡县| 土默特右旗| 肥东县| 泸西县| 阿尔山市| 湖南省| 巴塘县| 牙克石市| 观塘区| 图片| 应用必备| 黄浦区| 全南县| 郸城县| 海阳市| 呼玛县| 新源县| 云龙县| 万州区| 苍溪县| 满洲里市| 渭南市| 秭归县| 东海县|