MySQL多表連接的入門實例教程
連接可用于查詢,更新,建立事實外鍵(指人為建立的兩張表的對應關系,相對的,FORGIEN KEY也稱物理外鍵)
表的連接實質就是外鍵的逆向約束
連接條件
使用ON設定連接條件,也可以用WHERE代替.
一般情況下
- ON:設定連接條件
- WHERE:進行結果集記錄的過濾
沒有條件的JOIN內連接實質就是笛卡爾積
[INNER] JOIN 內連接
在MySQL中,JOIN, CROSS JOIN 和 INNER JOIN 是等價的。
內連接表示交集,僅顯示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;
使用內連接進行多表更新操作:
--將tdb_goods表中用中文存儲的goods_cate修改為tdb_goods_cates表中對應的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 關聯(lián)的附表 --goods_cate=cate_name 兩個表對應列的關系 --goods_cate=cate_id; 設置 值
外連接
內連接比外連接用的多一些.
若某字段只存在某一表,則另一表的里字段返回 NULL
LEFT [OUTER] JOIN 左外連接
顯示左表的全部記錄及右表符合連接條件的記錄。
- 如果使用LEFT JOIN,左表中存在一條記錄A,在右表中沒有找到相應的記錄,則返回結果會出現(xiàn)一條只有記錄A中的相應字段內容,其他字段都為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ù)表
在同一張表中既有父類,又有子類,本質上是一棵樹:

可以通過對同一張數(shù)據(jù)表的自身連接來進行查詢:
--查找顯示父類id對應的名稱 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對應的名稱 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; --查找有多少子級 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;
多表查詢并刪除
這里用自連接模擬兩張表,刪除該表中的重復項,保留goods_id 較小的記錄.
DELETE t1 FROM tdb_goods AS t1 LEFT JOIN( --選出goods_name重復的記錄 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)才行,這里沒有啟用 HAVING COUNT(goods_name)>=2) AS t2 --將t1與t2進行左連接,其實這里內連接和右連接也行 ON t1.goods_name=t2.goods_name --t1和t2的連接條件 WHERE t1.goods_id>t2.goods_id; --在LEFT JOIN結果集中,選出滿足t1.goods_id>t2.goods_id的記錄
為幫助理解,LEFT JOIN的結果為:
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。
相關文章
MySQL生成連續(xù)的數(shù)字/字符/時間序列的方法
有時候為了生成測試數(shù)據(jù),或者填充查詢結果中的數(shù)據(jù)間隔,需要使用到一個連續(xù)的數(shù)據(jù)序列值,所以,今天我們就來介紹一下如何在 MySQL 中生成連續(xù)的數(shù)字、字符以及時間序列值,需要的朋友可以參考下2024-04-04
Mysql中使用count加條件統(tǒng)計的實現(xiàn)示例
本文主要介紹了Mysql中使用count加條件統(tǒng)計的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-07-07
mysql查詢時offset過大影響性能的原因和優(yōu)化詳解
這篇文章主要給大家介紹了關于mysql查詢時offset過大影響性能的原因和優(yōu)化的相關資料,并在文末跟大家分享了MYSQL中l(wèi)imit,offset的區(qū)別,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧2018-06-06
MySQL數(shù)據(jù)中很多換行符和回車符的解決方法
這篇文章主要給大家介紹了關于MySQL數(shù)據(jù)中很多換行符和回車符的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-10-10

