真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

MySQL中怎么實現(xiàn)關(guān)聯(lián)查詢

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

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:域名與空間、網(wǎng)絡(luò)空間、營銷軟件、網(wǎng)站建設(shè)、武平網(wǎng)站維護(hù)、網(wǎng)站推廣。

MySQL
關(guān)聯(lián)查詢

前面,我們介紹的都是單表查詢(就是只從一張表中獲取數(shù)據(jù)),而實際應(yīng)用的時候,我們都會同時查詢多張表,這里,我們就介紹下,多表關(guān)聯(lián)查詢的使用。

SQL join 用于根據(jù)兩個或多個表中的列之間的關(guān)系,從這些表中查詢數(shù)據(jù)

MySQL中怎么實現(xiàn)關(guān)聯(lián)查詢

前置知識

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

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

測試數(shù)據(jù)參考:http://yuguiyang.github.io/2017/09/09/mysql-handbook-01/

inner join

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

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

MySQL中怎么實現(xiàn)關(guān)聯(lián)查詢

left join

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

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

MySQL中怎么實現(xiàn)關(guān)聯(lián)查詢

right join

右關(guān)聯(lián),和做關(guān)聯(lián)類似,但已右表為主表

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

MySQL中怎么實現(xiàn)關(guān)聯(lián)查詢

full outer join

全關(guān)聯(lián),mysql沒有full join 語法,我們可以通過使用union來實現(xiàn)

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中怎么實現(xiàn)關(guān)聯(lián)查詢

cross join

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

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

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


網(wǎng)頁標(biāo)題:MySQL中怎么實現(xiàn)關(guān)聯(lián)查詢
網(wǎng)站鏈接:http://weahome.cn/article/pecoop.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部