欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL多表連接的入門實例教程

 更新時間:2019年12月25日 08:33:36   作者:EricMa  
這篇文章主要給大家介紹了關(guān)于MySQL多表連接的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

連接可用于查詢,更新,建立事實外鍵(指人為建立的兩張表的對應(yīng)關(guān)系,相對的,FORGIEN KEY也稱物理外鍵)

表的連接實質(zhì)就是外鍵的逆向約束

連接條件

使用ON設(shè)定連接條件,也可以用WHERE代替.

一般情況下

  • ON:設(shè)定連接條件
  • WHERE:進行結(jié)果集記錄的過濾

沒有條件的JOIN內(nèi)連接實質(zhì)就是笛卡爾積

[INNER] JOIN 內(nèi)連接

在MySQL中,JOIN, CROSS JOIN 和 INNER JOIN 是等價的。

內(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)連接進行多表更新操作:

--將tdb_goods表中用中文存儲的goods_cate修改為tdb_goods_cates表中對應(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 兩個表對應(yīng)列的關(guān)系
--goods_cate=cate_id; 設(shè)置 值

外連接

內(nèi)連接比外連接用的多一些.

若某字段只存在某一表,則另一表的里字段返回 NULL

LEFT [OUTER] JOIN 左外連接

顯示左表的全部記錄及右表符合連接條件的記錄。

  • 如果使用LEFT JOIN,左表中存在一條記錄A,在右表中沒有找到相應(yīng)的記錄,則返回結(jié)果會出現(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è)計無限分類數(shù)據(jù)表

在同一張表中既有父類,又有子類,本質(zhì)上是一棵樹:

可以通過對同一張數(shù)據(jù)表的自身連接來進行查詢:

--查找顯示父類id對應(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對應(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;

--查找有多少子級
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ù)項,保留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)才行,這里沒有啟用
 HAVING COUNT(goods_name)>=2) 
AS t2 --將t1與t2進行左連接,其實這里內(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é)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。

相關(guān)文章

  • Mysql如何同時交換兩個表的表名詳解

    Mysql如何同時交換兩個表的表名詳解

    這篇文章主要給大家介紹了關(guān)于Mysql如何同時交換兩個表的表名,以及MySQL命令rename修改表名的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-01-01
  • 學(xué)習(xí)mysql?如何行轉(zhuǎn)列與列傳行

    學(xué)習(xí)mysql?如何行轉(zhuǎn)列與列傳行

    這篇文章主要介紹了mysql行轉(zhuǎn)列與列傳行的使用方法,幫助大家更好的理解和學(xué)習(xí)MySQL的使用,語句不難,但有一定的知識參考價值,需要的朋友可以參考一下,希望給你的學(xué)習(xí)帶來幫助
    2022-02-02
  • MySQL生成連續(xù)的數(shù)字/字符/時間序列的方法

    MySQL生成連續(xù)的數(shù)字/字符/時間序列的方法

    有時候為了生成測試數(shù)據(jù),或者填充查詢結(jié)果中的數(shù)據(jù)間隔,需要使用到一個連續(xù)的數(shù)據(jù)序列值,所以,今天我們就來介紹一下如何在 MySQL 中生成連續(xù)的數(shù)字、字符以及時間序列值,需要的朋友可以參考下
    2024-04-04
  • MySQL存儲過程及常用函數(shù)代碼解析

    MySQL存儲過程及常用函數(shù)代碼解析

    這篇文章主要介紹了MySQL存儲過程及常用函數(shù)代碼解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-08-08
  • Mysql中使用count加條件統(tǒng)計的實現(xiàn)示例

    Mysql中使用count加條件統(tǒng)計的實現(xiàn)示例

    本文主要介紹了Mysql中使用count加條件統(tǒng)計的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • MySQL 中查找含有目標字段的表的方法

    MySQL 中查找含有目標字段的表的方法

    這篇文章主要介紹了MySQL 中查找含有目標字段的表的方法,即查找某個字段在哪個表中,這在一些場景中非常有用,需要的朋友可以參考下
    2015-06-06
  • mysql查詢時offset過大影響性能的原因和優(yōu)化詳解

    mysql查詢時offset過大影響性能的原因和優(yōu)化詳解

    這篇文章主要給大家介紹了關(guān)于mysql查詢時offset過大影響性能的原因和優(yōu)化的相關(guān)資料,并在文末跟大家分享了MYSQL中l(wèi)imit,offset的區(qū)別,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-06-06
  • MySQL多實例配置方案

    MySQL多實例配置方案

    MySQL多實例就是,在一臺機器上開啟多個不同的服務(wù)端口(如:3306,3307,3308...),運行多個MySQL服務(wù)進程,這些服務(wù)進程通過不同的socket監(jiān)聽不同的端口提供服務(wù)。
    2018-04-04
  • MySQL數(shù)據(jù)中很多換行符和回車符的解決方法

    MySQL數(shù)據(jù)中很多換行符和回車符的解決方法

    這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)中很多換行符和回車符的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • MySQL如何優(yōu)化查詢速度

    MySQL如何優(yōu)化查詢速度

    這篇文章主要介紹了MySQL如何優(yōu)化查詢速度,幫助大家提升自己的數(shù)據(jù)庫性能,感興趣的朋友可以了解下
    2020-08-08

最新評論