婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > MySQL多表連接的入門(mén)實(shí)例教程

MySQL多表連接的入門(mén)實(shí)例教程

熱門(mén)標(biāo)簽:銷(xiāo)售語(yǔ)音電話(huà)機(jī)器人 巫師三血與酒地圖標(biāo)注 萊西市地圖標(biāo)注 400電話(huà)申請(qǐng)信用卡 走過(guò)哪個(gè)省地圖標(biāo)注 安徽ai電話(huà)電銷(xiāo)機(jī)器人有效果嗎 常州網(wǎng)絡(luò)外呼系統(tǒng)開(kāi)發(fā) 外呼系統(tǒng)電銷(xiāo)受騙 在哪里申請(qǐng)400電話(huà)

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

表的連接實(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類(lèi)似).

RIGHT [OUTER] JOIN 右外連接

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

多表連接

跟兩張表的連接類(lèi)似

如三張表的連接:

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ú)限分類(lèi)數(shù)據(jù)表

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

可以通過(guò)對(duì)同一張數(shù)據(jù)表的自身連接來(lái)進(jìn)行查詢(xún):

--查找顯示父類(lèi)id對(duì)應(yīng)的名稱(chē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;

--查找子類(lèi)id對(duì)應(yīng)的名稱(chē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;

多表查詢(xún)并刪除

這里用自連接模擬兩張表,刪除該表中的重復(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é)果集中,選出滿(mǎn)足t1.goods_id>t2.goods_id的記錄

為幫助理解,LEFT JOIN的結(jié)果為:

總結(jié)

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

您可能感興趣的文章:
  • 淺談Mysql多表連接查詢(xún)的執(zhí)行細(xì)節(jié)
  • mysql多表連接查詢(xún)實(shí)例講解
  • mysql delete 多表連接刪除功能
  • MySQL中基本的多表連接查詢(xún)教程
  • MySQL多表連接查詢(xún)?cè)斀?/li>

標(biāo)簽:果洛 黃石 陽(yáng)江 河北 煙臺(tái) 來(lái)賓 鞍山 赤峰

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL多表連接的入門(mén)實(shí)例教程》,本文關(guān)鍵詞  MySQL,多表,連接,的,入門(mén),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL多表連接的入門(mén)實(shí)例教程》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于MySQL多表連接的入門(mén)實(shí)例教程的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 长阳| 益阳市| 边坝县| 元谋县| 宿迁市| 马龙县| 绩溪县| 潼南县| 枞阳县| 炎陵县| 辉县市| 将乐县| 四子王旗| 张家港市| 贺兰县| 丁青县| 且末县| 柳林县| 西畴县| 荃湾区| 左云县| 明星| 洪江市| 泾阳县| 英德市| 文昌市| 顺昌县| 龙川县| 南平市| 屯留县| 临城县| 潮州市| 丹阳市| 洛浦县| 静宁县| 百色市| 扎囊县| 新闻| 杭锦后旗| 监利县| 阜南县|