MySQL多表連接的入門實(shí)例教程
連接可用于查詢,更新,建立事實(shí)外鍵(指人為建立的兩張表的對(duì)應(yīng)關(guān)系,相對(duì)的,FORGIEN KEY也稱物理外鍵)
表的連接實(shí)質(zhì)就是外鍵的逆向約束
連接條件
使用ON設(shè)定連接條件,也可以用WHERE代替.
一般情況下
- ON:設(shè)定連接條件
- WHERE:進(jìn)行結(jié)果集記錄的過(guò)濾
沒(méi)有條件的JOIN內(nèi)連接實(shí)質(zhì)就是笛卡爾積
[INNER] JOIN 內(nèi)連接
在MySQL中,JOIN, CROSS JOIN 和 INNER JOIN 是等價(jià)的。
內(nèi)連接表示交集,僅顯示A、B兩表符合連接條件的記錄。不符合連接條件的記錄不顯示。
SELECT goods_id,goods_name,cate_name FROM tdb_goods INNER JOIN tdb_goods_cate ON tdb_goods.cate_id = tdb_goods_cate.cate_id;
使用內(nèi)連接進(jìn)行多表更新操作:
--將tdb_goods表中用中文存儲(chǔ)的goods_cate修改為tdb_goods_cates表中對(duì)應(yīng)的cate_id,以節(jié)省空間 UPDATE tdb_goods INNER JOIN tdb_goods_cates ON goods_cate=cate_name SET goods_cate=cate_id; --tdb_goods 想要更改的表名 --tdb_goods_cates 關(guān)聯(lián)的附表 --goods_cate=cate_name 兩個(gè)表對(duì)應(yīng)列的關(guān)系 --goods_cate=cate_id; 設(shè)置 值
外連接
內(nèi)連接比外連接用的多一些.
若某字段只存在某一表,則另一表的里字段返回 NULL
LEFT [OUTER] JOIN 左外連接
顯示左表的全部記錄及右表符合連接條件的記錄。
- 如果使用LEFT JOIN,左表中存在一條記錄A,在右表中沒(méi)有找到相應(yīng)的記錄,則返回結(jié)果會(huì)出現(xiàn)一條只有記錄A中的相應(yīng)字段內(nèi)容,其他字段都為NULL的記錄(RIGHT JOIN類似).
RIGHT [OUTER] JOIN 右外連接
顯示右表的全部記錄及左表符合連接條件的記錄。
多表連接
跟兩張表的連接類似
如三張表的連接:
SELECT goods_id,goods_name,b.cate_name,c.brand_name,goods_price FROM products AS a INNER JOIN products_cate AS b ON a.goods_cate = b.cate_id INNER JOIN products_brand AS c ON a.brand_name = c.brand_id;
自連接
設(shè)計(jì)無(wú)限分類數(shù)據(jù)表
在同一張表中既有父類,又有子類,本質(zhì)上是一棵樹(shù):

可以通過(guò)對(duì)同一張數(shù)據(jù)表的自身連接來(lái)進(jìn)行查詢:
--查找顯示父類id對(duì)應(yīng)的名稱 SELECT s.type_id,s.type_name,p.type_name AS parent_name FROM tdb_goods_types AS s LEFT JOIN tdb_goods_types AS p ON s.parent_id=p.type_id; --查找子類id對(duì)應(yīng)的名稱 SELECT p.type_id,p.type_name,s.type_name AS child_name FROM tdb_goods_types AS p LEFT JOIN tdb_goods_types AS s ON p.type_id=s.parent_id; --查找有多少子級(jí) SELECT p.type_id,p.type_name,COUNT(s.type_name) AS child_count FROM tdb_goods_types AS p LEFT JOIN tdb_goods_types AS s ON p.type_id=s.parent_id GROUP BY p.type_name ORDER BY p.type_id;
多表查詢并刪除
這里用自連接模擬兩張表,刪除該表中的重復(fù)項(xiàng),保留goods_id 較小的記錄.
DELETE t1 FROM tdb_goods AS t1 LEFT JOIN( --選出goods_name重復(fù)的記錄 SELECT goods_id,goods_name FROM tdb_goods GROUP BY goods_name --MySQL 5.7.5以上版本啟用了only_full_group_by SQL模式,select的列都要在group中,或者本身是聚合列(SUM,AVG,MAX,MIN)才行,這里沒(méi)有啟用 HAVING COUNT(goods_name)>=2) AS t2 --將t1與t2進(jìn)行左連接,其實(shí)這里內(nèi)連接和右連接也行 ON t1.goods_name=t2.goods_name --t1和t2的連接條件 WHERE t1.goods_id>t2.goods_id; --在LEFT JOIN結(jié)果集中,選出滿足t1.goods_id>t2.goods_id的記錄
為幫助理解,LEFT JOIN的結(jié)果為:
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
MySQL去重中distinct和group?by的區(qū)別淺析
今天無(wú)意中聽(tīng)到有同事在討論,distinct和group by有什么區(qū)別,下面這篇文章主要給大家介紹了關(guān)于MySQL去重中distinct和group?by區(qū)別的相關(guān)資料,需要的朋友可以參考下2022-11-11
MySQL 修改數(shù)據(jù)庫(kù)名稱的一個(gè)新奇方法
這篇文章主要介紹了MySQL 修改數(shù)據(jù)庫(kù)名稱的一個(gè)新奇方法,MySQL 修改數(shù)據(jù)庫(kù)名的一個(gè)變通方法,需要的朋友可以參考下2014-07-07
MySQL刪除和插入數(shù)據(jù)很慢的問(wèn)題解決
公司開(kāi)發(fā)人員在測(cè)試環(huán)境中執(zhí)行一條 insert 語(yǔ)句時(shí),需要花費(fèi) 10 幾秒才可以執(zhí)行成功。所以本文就來(lái)解決一下這個(gè)問(wèn)題,感興趣的小伙伴們可以參考一下2021-06-06
淺談mysql的sql_mode可能會(huì)限制你的查詢
本文主要介紹了淺談mysql的sql_mode可能會(huì)限制你的查詢,這個(gè)問(wèn)題主要說(shuō)明的是,我們寫的sql查詢語(yǔ)句違背了聚合函數(shù)group?by的規(guī)則,下面就來(lái)介紹一下解決方法,感興趣的可以了解一下2025-03-03
mysql數(shù)據(jù)損壞,如何通過(guò)ibd和frm文件批量恢復(fù)數(shù)據(jù)庫(kù)數(shù)據(jù)
這篇文章主要介紹了mysql數(shù)據(jù)損壞,如何通過(guò)ibd和frm文件批量恢復(fù)數(shù)據(jù)庫(kù)數(shù)據(jù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
MySQL優(yōu)化總結(jié)-查詢總條數(shù)
這篇文章主要介紹了MySQL優(yōu)化總結(jié)-查詢總條數(shù)的相關(guān)內(nèi)容,文中進(jìn)行簡(jiǎn)單的測(cè)試對(duì)比,具有一定參考價(jià)值,需要的朋友可以了解下。2017-10-10
MySQL實(shí)現(xiàn)merge?into四種方法代碼實(shí)例
Merge?into是一個(gè)數(shù)據(jù)庫(kù)操作術(shù)語(yǔ),通常用于將兩個(gè)或多個(gè)表中的數(shù)據(jù)合并到一個(gè)表中,這篇文章主要給大家介紹了關(guān)于MySQL實(shí)現(xiàn)merge?into四種方法的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-07-07

