久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

mysql如何實(shí)現(xiàn)多表連接查詢

159次閱讀
沒有評論

共計(jì) 3365 個(gè)字符,預(yù)計(jì)需要花費(fèi) 9 分鐘才能閱讀完成。

自動(dòng)寫代碼機(jī)器人,免費(fèi)開通

這篇文章給大家分享的是有關(guān) mysql 如何實(shí)現(xiàn)多表連接查詢的內(nèi)容。丸趣 TV 小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨丸趣 TV 小編過來看看吧。

實(shí)際的項(xiàng)目,存在多張表的關(guān)聯(lián)關(guān)系。不可能在一張表里面就能檢索出所有數(shù)據(jù)。如果沒有表連接的話,那么我們就需要非常多的操作。比如需要從 A 表找出限制性的條件來從 B 表中檢索數(shù)據(jù)。不但需要分多表來操作,而且效率也不高。比如書中的例子:

代碼如下:

SELECT FId
FROM T_Customer
WHERE FName= MIKE

這個(gè) SQL 語句返回 2,也就是姓名為 MIKE 的客戶的 FId 值為 2,這樣就可以到 T_Order 中檢索 FCustomerId 等于 2 的記錄:

代碼如下:

SELECT FNumber,FPrice
FROM T_Order
WHERE FCustomerId=2

下面我們詳細(xì)來看看表連接。表連接有多種不同的類型,有交叉連接(CROSS JOIN)、內(nèi)連接(INNER JOIN)、外連接(OUTTER JOIN)。

(1)內(nèi)連接(INNER JOIN):內(nèi)連接組合兩張表,并且只獲取滿足兩表連接條件的數(shù)據(jù)。

代碼如下:

SELECT o.FId,o.FNumber,o.FPrice,
c.FId,c.FName,c .FAge
FROM T_Order o JOIN T_Customer c
ON o.FCustomerId= c.FId

注:在大多數(shù)數(shù)據(jù)庫系統(tǒng)中,INNER JOIN 中的 INNER 是可選的,INNER JOIN 是默認(rèn)的連接方式。

在使用表連接的時(shí)候可以不局限于只連接兩張表,因?yàn)橛泻芏嗲闆r下需要聯(lián)系許多表。例如,T_Order 表同時(shí)還需要連接 T_Customer 和 T_OrderType 兩張表才能檢索到所需要的信息,編寫如下 SQL 語句即可:

代碼如下:

SELECT o.FId,o.FNumber,o.FPrice,
c.FId,c.FName,c .FAge
FROM T_Order o JOIN T_Customer c
ON o.FCustomerId= c.FId
INNER JOIN T_OrderType
ON T_Order.FTypeId= T_OrderType.FId

(2)交叉連接(CROSS JOIN):交叉連接所有涉及的表中的所有記錄都包含在結(jié)果集中。可以采用兩種方式來定義交叉連接,分別是隱式和顯式的連接。

下面看看隱式的例子:

代碼如下:

SELECT T_Customer.FId, T_Customer.FName, T_Customer.FAge,
T_Order.FId, T_Order.FNumber, T_Order.FPrice
FROM T_Customer, T_Order

使用顯式的連接則需要使用 CROSS JOIN,例子如下:

代碼如下:

SELECT T_Customer.FId, T_Customer.FName, T_Customer.FAge,
T_Order.FId, T_Order.FNumber, T_Order.FPrice
FROM T_Customer
CROSS JOIN T_Order

(3)外連接(OUTTER JOIN):內(nèi)部連接只獲取滿足連接條件的數(shù)據(jù),而對于外部連接來說,主要是解決這樣的一種場景。滿足條件的數(shù)據(jù)檢索出來,這個(gè)沒有疑問,外部連接還會(huì)檢索另一部分?jǐn)?shù)據(jù),那就是將不滿足條件的數(shù)據(jù)以 NULL 來填充。先來看一下外連接的分類:左外部連接(LEFT OUTER JOIN)、右外部連接(RIGHT OUTER JOIN)和全外部連接(FULLOUTER JOIN)。

I、左外部連接(LEFT OUTER JOIN):前頭也說了,將不滿足條件的數(shù)據(jù)以 NULL 來填充。那么具體是哪些需要以 NULL 來填充呢,對于左外連接來說的話,連接條件當(dāng)中,如果出現(xiàn)滿足條件的左表的數(shù)據(jù)在右表中沒有相應(yīng)匹配時(shí),需要把相應(yīng)的右表字段填充 NULL 值。也就是說左外部連接的主體是左表,右表來配合。

代碼如下:

SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
LEFT OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId

注:如果使用左外部連接的話,通過 where 語句能過濾其中不符合的數(shù)據(jù)

代碼如下:

SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
LEFT OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId
WHERE o.FPrice =150

II、右外部連接(RIGHT OUTER JOIN):右外部連接與左外連部接相反,將會(huì)被填充 NULL 值的是左表的字段。也就是說右外部連接的主體是右表,左表來配合。

代碼如下:

SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
RIGHT OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId

注:同左外連接一樣,可以使用 where 語句進(jìn)行過濾

III、全外部連接(FULLOUTER JOIN): 全外部連接是左外部連接和右外部連接的合集。也就是既包括左外部連接的結(jié)果集,也包括右外部連接的結(jié)果集。

代碼如下:

SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
FULL OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId

其結(jié)果相當(dāng)于:

SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
LEFT OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId
UNION
SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
RIGHT OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId

=======================================================================================

多表查詢的多種 sql 寫法:(下面是從兩個(gè)表里查詢 也可以看成從三個(gè)表里查詢 , 顯示表 v_goods 里的所有字段,顯示 admin2 表里的 name 字段作為添加人,顯示表 admin2 表的 name 字段作為操作人)  多個(gè)表的查詢都可按照下面三個(gè)例句進(jìn)行編寫 sql

SELECT v.*,(SELECT a.name FROM admin2 a WHERE a.adminId=v.loadInId) AS aname,(SELECT a.name FROM admin2 a WHERE a.adminId=v.operatorId) AS uname FROM v_goods v where 1=1;
SELECT v.*,a.name aname,b.name uname FROM v_goods v,admin2 a,admin2 b WHERE a.adminId=v.loadInId AND b.adminId=v.operatorId ;
SELECT v.*,a.name aname,b.name uname FROM v_goods v LEFT JOIN admin2 a ON a.adminId=v.loadInId LEFT JOIN admin2 b ON b.adminId=v.operatorId ;

感謝各位的閱讀!關(guān)于“mysql 如何實(shí)現(xiàn)多表連接查詢”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向 AI 問一下細(xì)節(jié)

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-12-04發(fā)表,共計(jì)3365字。
轉(zhuǎn)載說明:除特殊說明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 绥棱县| 客服| 明溪县| 汉沽区| 克拉玛依市| 三都| 梅河口市| 林口县| 民和| 洛隆县| 临邑县| 怀远县| 兴义市| 靖州| 隆林| 南昌市| 唐河县| 邢台县| 栾川县| 曲阜市| 介休市| 平昌县| 扬中市| 板桥市| 蛟河市| 新干县| 安国市| 榆树市| 辉县市| 新巴尔虎左旗| 舒兰市| 江安县| 贵州省| 苏州市| 清涧县| 简阳市| 聂荣县| 射阳县| 德兴市| 塔河县| 成都市|