中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

幾種MySQL中的聯(lián)接查詢操作方法總結(jié)
來(lái)源:易賢網(wǎng) 閱讀:1487 次 日期:2015-04-15 10:08:53
溫馨提示:易賢網(wǎng)小編為您整理了“幾種MySQL中的聯(lián)接查詢操作方法總結(jié)”,方便廣大網(wǎng)友查閱!

前言

現(xiàn)在系統(tǒng)的各種業(yè)務(wù)是如此的復(fù)雜,數(shù)據(jù)都存在數(shù)據(jù)庫(kù)中的各種表中,這個(gè)主鍵啊,那個(gè)外鍵啊,而表與表之間就依靠著這些主鍵和外鍵聯(lián)系在一起。而我們進(jìn)行業(yè)務(wù)操作時(shí),就需要在多個(gè)表之間,使用sql語(yǔ)句建立起關(guān)系,然后再進(jìn)行各種sql操作。那么在使用sql寫(xiě)出各種操作時(shí),如何使用sql語(yǔ)句,將多個(gè)表關(guān)聯(lián)在一起,進(jìn)行業(yè)務(wù)操作呢?而這篇文章,就對(duì)這個(gè)知識(shí)點(diǎn)進(jìn)行總結(jié)。

聯(lián)接查詢是一種常見(jiàn)的數(shù)據(jù)庫(kù)操作,即在兩張表(多張表)中進(jìn)行匹配的操作。MySQL數(shù)據(jù)庫(kù)支持如下的聯(lián)接查詢:

CROSS JOIN(交叉聯(lián)接)

INNER JOIN(內(nèi)聯(lián)接)

OUTER JOIN(外聯(lián)接)

其它

在進(jìn)行各種聯(lián)接操作時(shí),一定要回憶一下在《SQL邏輯查詢語(yǔ)句執(zhí)行順序》這篇文章中總結(jié)的SQL邏輯查詢語(yǔ)句執(zhí)行的前三步:

執(zhí)行FROM語(yǔ)句(笛卡爾積)

執(zhí)行ON過(guò)濾

添加外部行

每個(gè)聯(lián)接都只發(fā)生在兩個(gè)表之間,即使FROM子句中包含多個(gè)表也是如此。每次聯(lián)接操作也只進(jìn)行邏輯查詢語(yǔ)句的前三步,每次產(chǎn)生一個(gè)虛擬表,這個(gè)虛擬表再依次與FROM子句的下一個(gè)表進(jìn)行聯(lián)接,重復(fù)上述步驟,直到FROM子句中的表都被處理完為止。

前期準(zhǔn)備

1.新建一個(gè)測(cè)試數(shù)據(jù)庫(kù)TestDB;

create database TestDB;

創(chuàng)建測(cè)試表table1和table2;

CREATE TABLE table1 ( customer_id VARCHAR(10) NOT NULL, city VARCHAR(10) NOT NULL, PRIMARY KEY(customer_id) )ENGINE=INNODB DEFAULT CHARSET=UTF8; CREATE TABLE table2 ( order_id INT NOT NULL auto_increment, customer_id VARCHAR(10), PRIMARY KEY(order_id) )ENGINE=INNODB DEFAULT CHARSET=UTF8;

插入測(cè)試數(shù)據(jù);

INSERT INTO table1(customer_id,city) VALUES('163','hangzhou'); INSERT INTO table1(customer_id,city) VALUES('9you','shanghai'); INSERT INTO table1(customer_id,city) VALUES('tx','hangzhou'); INSERT INTO table1(customer_id,city) VALUES('baidu','hangzhou'); INSERT INTO table2(customer_id) VALUES('163'); INSERT INTO table2(customer_id) VALUES('163'); INSERT INTO table2(customer_id) VALUES('9you'); INSERT INTO table2(customer_id) VALUES('9you'); INSERT INTO table2(customer_id) VALUES('9you'); INSERT INTO table2(customer_id) VALUES('tx');

準(zhǔn)備工作做完以后,table1和table2看起來(lái)應(yīng)該像下面這樣:

mysql> select * from table1; +-------------+----------+ | customer_id | city | +-------------+----------+ | 163 | hangzhou | | 9you | shanghai | | baidu | hangzhou | | tx | hangzhou | +-------------+----------+ 4 rows in set (0.00 sec) mysql> select * from table2; +----------+-------------+ | order_id | customer_id | +----------+-------------+ | 1 | 163 | | 2 | 163 | | 3 | 9you | | 4 | 9you | | 5 | 9you | | 6 | tx | +----------+-------------+ 7 rows in set (0.00 sec)

準(zhǔn)備工作做的差不多了,開(kāi)始今天的總結(jié)吧。

CROSS JOIN聯(lián)接(交叉聯(lián)接)

CROSS JOIN對(duì)兩個(gè)表執(zhí)行FROM語(yǔ)句(笛卡爾積)操作,返回兩個(gè)表中所有列的組合。如果左表有m行數(shù)據(jù),右表有n行數(shù)據(jù),則執(zhí)行CROSS JOIN將返回m*n行數(shù)據(jù)。CROSS JOIN只執(zhí)行SQL邏輯查詢語(yǔ)句執(zhí)行的前三步中的第一步。

CROSS JOIN可以干什么?由于CROSS JOIN只執(zhí)行笛卡爾積操作,并不會(huì)進(jìn)行過(guò)濾,所以,我們?cè)趯?shí)際中,可以使用CROSS JOIN生成大量的測(cè)試數(shù)據(jù)。

對(duì)上述測(cè)試數(shù)據(jù),使用以下查詢:

select * from table1 cross join table2;

就會(huì)得到以下結(jié)果:

+-------------+----------+----------+-------------+ | customer_id | city | order_id | customer_id | +-------------+----------+----------+-------------+ | 163 | hangzhou | 1 | 163 | | 9you | shanghai | 1 | 163 | | baidu | hangzhou | 1 | 163 | | tx | hangzhou | 1 | 163 | | 163 | hangzhou | 2 | 163 | | 9you | shanghai | 2 | 163 | | baidu | hangzhou | 2 | 163 | | tx | hangzhou | 2 | 163 | | 163 | hangzhou | 3 | 9you | | 9you | shanghai | 3 | 9you | | baidu | hangzhou | 3 | 9you | | tx | hangzhou | 3 | 9you | | 163 | hangzhou | 4 | 9you | | 9you | shanghai | 4 | 9you | | baidu | hangzhou | 4 | 9you | | tx | hangzhou | 4 | 9you | | 163 | hangzhou | 5 | 9you | | 9you | shanghai | 5 | 9you | | baidu | hangzhou | 5 | 9you | | tx | hangzhou | 5 | 9you | | 163 | hangzhou | 6 | tx | | 9you | shanghai | 6 | tx | | baidu | hangzhou | 6 | tx | | tx | hangzhou | 6 | tx | +-------------+----------+----------+-------------+

INNER JOIN聯(lián)接(內(nèi)聯(lián)接)

INNER JOIN比CROSS JOIN強(qiáng)大的一點(diǎn)在于,INNER JOIN可以根據(jù)一些過(guò)濾條件來(lái)匹配表之間的數(shù)據(jù)。在SQL邏輯查詢語(yǔ)句執(zhí)行的前三步中,INNER JOIN會(huì)執(zhí)行第一步和第二步;即沒(méi)有第三步,不添加外部行,這是INNER JOIN和接下來(lái)要說(shuō)的OUTER JOIN的最大區(qū)別之一。

現(xiàn)在來(lái)看看使用INNER JOIN來(lái)查詢一下:

select * from table1 inner join table2 on table1.customer_id=table2.customer_id;

就會(huì)得到以下結(jié)果:

+-------------+----------+----------+-------------+ | customer_id | city | order_id | customer_id | +-------------+----------+----------+-------------+ | 163 | hangzhou | 1 | 163 | | 163 | hangzhou | 2 | 163 | | 9you | shanghai | 3 | 9you | | 9you | shanghai | 4 | 9you | | 9you | shanghai | 5 | 9you | | tx | hangzhou | 6 | tx | +-------------+----------+----------+-------------+

對(duì)于INNER JOIN來(lái)說(shuō),如果沒(méi)有使用ON條件的過(guò)濾,INNER JOIN和CROSS JOIN的效果是一樣的。當(dāng)在ON中設(shè)置的過(guò)濾條件列具有相同的名稱,我們可以使用USING關(guān)鍵字來(lái)簡(jiǎn)寫(xiě)ON的過(guò)濾條件,這樣可以簡(jiǎn)化sql語(yǔ)句,例如:

select * from table1 inner join table2 using(customer_id);

在實(shí)際編寫(xiě)sql語(yǔ)句時(shí),我們都可以省略掉INNER關(guān)鍵字,例如:

select * from table1 join table2 on table1.customer_id=table2.customer_id;

但是,請(qǐng)記住,這還是INNER JOIN。

OUTER JOIN聯(lián)接(外聯(lián)接)

哦,記得有一次參加面試,還問(wèn)我這個(gè)問(wèn)題來(lái)著,那在這里再好好的總結(jié)一下。通過(guò)OUTER JOIN,我們可以按照一些過(guò)濾條件來(lái)匹配表之間的數(shù)據(jù)。OUTER JOIN的結(jié)果集等于INNER JOIN的結(jié)果集加上外部行;也就是說(shuō),在使用OUTER JOIN時(shí),SQL邏輯查詢語(yǔ)句執(zhí)行的前三步,都會(huì)執(zhí)行一遍。關(guān)于如何添加外部行,請(qǐng)參考《SQL邏輯查詢語(yǔ)句執(zhí)行順序》這篇文章中的添加外部行部分內(nèi)容。

MySQL數(shù)據(jù)庫(kù)支持LEFT OUTER JOIN和RIGHT OUTER JOIN,與INNER關(guān)鍵字一樣,我們可以省略O(shè)UTER關(guān)鍵字。對(duì)于OUTER JOIN,同樣的也可以使用USING來(lái)簡(jiǎn)化ON子句。所以,對(duì)于以下sql語(yǔ)句:

select * from table1 left outer join table2 on table1.customer_id=table2.customer_id;

我們可以簡(jiǎn)寫(xiě)成這樣:

select * from table1 left join table2 using(customer_id);

但是,與INNER JOIN還有一點(diǎn)區(qū)別是,對(duì)于OUTER JOIN,必須指定ON(或者using)子句,否則MySQL數(shù)據(jù)庫(kù)會(huì)拋出異常。

NATURAL JOIN聯(lián)接(自然連接)

NATURAL JOIN等同于INNER(OUTER) JOIN與USING的組合,它隱含的作用是將兩個(gè)表中具有相同名稱的列進(jìn)行匹配。同樣的,NATURAL LEFT(RIGHT) JOIN等同于LEFT(RIGHT) JOIN與USING的組合。比如:

select * from table1 join table2 using(customer_id);

select * from table1 natural join table2;

等價(jià)。

在比如:

select * from table1 left join table2 using(customer_id);

select * from table1 natural left join table2;

等價(jià)。

STRAIGHT_JOIN聯(lián)接

STRAIGHT_JOIN并不是一個(gè)新的聯(lián)接類型,而是用戶對(duì)sql優(yōu)化器的控制,其等同于JOIN。通過(guò)STRAIGHT_JOIN,MySQL數(shù)據(jù)庫(kù)會(huì)強(qiáng)制先讀取左邊的表。舉個(gè)例子來(lái)說(shuō),比如以下sql語(yǔ)句:

explain select * from table1 join table2 on table1.customer_id=table2.customer_id;

它的主要輸出部分如下:

+----+-------------+--------+------+---------------+ | id | select_type | table | type | possible_keys | +----+-------------+--------+------+---------------+ | 1 | SIMPLE | table2 | ALL | NULL | | 1 | SIMPLE | table1 | ALL | PRIMARY | +----+-------------+--------+------+---------------+

我們可以很清楚的看到,MySQL是先選擇的table2表,然后再進(jìn)行的匹配。如果我們指定STRAIGHT_JOIN方式,例如:

explain select * from table1 straight_join table2 on table1.customer_id=table2.customer_id;

上述語(yǔ)句的主要輸出部分如下:

+----+-------------+--------+------+---------------+ | id | select_type | table | type | possible_keys | +----+-------------+--------+------+---------------+ | 1 | SIMPLE | table1 | ALL | PRIMARY | | 1 | SIMPLE | table2 | ALL | NULL | +----+-------------+--------+------+---------------+

可以看到,當(dāng)指定STRAIGHT_JOIN方式以后,MySQL就會(huì)先選擇table1表,然后再進(jìn)行的匹配。

那么就有讀者問(wèn)了,這有啥好處呢?性能,還是性能。由于我這里測(cè)試數(shù)據(jù)比較少,大進(jìn)行大量數(shù)據(jù)的訪問(wèn)時(shí),我們指定STRAIGHT_JOIN讓MySQL先讀取左邊的表,讓MySQL按照我們的意愿來(lái)完成聯(lián)接操作。在進(jìn)行性能優(yōu)化時(shí),我們可以考慮使用STRAIGHT_JOIN。

多表聯(lián)接

在上面的所有例子中,我都是使用的兩個(gè)表之間的聯(lián)接,而更多時(shí)候,我們?cè)诠ぷ髦校赡懿恢挂?lián)接兩張表,可能要涉及到三張或者更多張表的聯(lián)接查詢操作。

對(duì)于INNER JOIN的多表聯(lián)接查詢,可以隨意安排表的順序,而不會(huì)影響查詢的結(jié)果。這是因?yàn)閮?yōu)化器會(huì)自動(dòng)根據(jù)成本評(píng)估出訪問(wèn)表的順序。如果你想指定聯(lián)接順序,可以使用上面總結(jié)的STRAIGHT_JOIN。

而對(duì)于OUTER JOIN的多表聯(lián)接查詢,表的位置不同,涉及到添加外部行的問(wèn)題,就可能會(huì)影響最終的結(jié)果。

總結(jié)

這是MySQL中聯(lián)接操作的全部?jī)?nèi)容了,內(nèi)容雖多,但是都還比較簡(jiǎn)單,結(jié)合文章中的例子,再自己實(shí)際操作一遍,完全可以搞定的。這一篇文章就這樣了。

更多信息請(qǐng)查看IT技術(shù)專欄

更多信息請(qǐng)查看數(shù)據(jù)庫(kù)
易賢網(wǎng)手機(jī)網(wǎng)站地址:幾種MySQL中的聯(lián)接查詢操作方法總結(jié)
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢?yōu)闇?zhǔn)!

2026上岸·考公考編培訓(xùn)報(bào)班

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
亚洲美女精品成人在线视频| 99精品欧美一区二区三区综合在线| 欧美极品一区| 欧美黑人在线播放| 欧美系列电影免费观看| 国产香蕉97碰碰久久人人| 亚洲国产欧美一区二区三区同亚洲| 99成人精品| 欧美一区精品| 欧美精品在线一区| 国产精品综合不卡av| 亚洲国产一区二区三区a毛片| 一区二区三区成人| 久久九九久精品国产免费直播| 欧美激情亚洲自拍| 国内精品伊人久久久久av一坑| 9l国产精品久久久久麻豆| 欧美专区在线观看一区| 欧美日韩国产精品一区| 精品动漫3d一区二区三区| 亚洲一区三区视频在线观看| 噜噜噜在线观看免费视频日韩| 国产精品久久网站| 亚洲免费观看高清在线观看| 久久亚洲国产精品一区二区| 国产精品久久久久久一区二区三区| 亚洲成色777777女色窝| 欧美一区二区三区另类| 欧美日韩在线直播| 亚洲精品日本| 欧美成人按摩| 伊人天天综合| 久久精品一二三区| 国产欧美日韩不卡| 亚洲欧美国产高清| 欧美性猛片xxxx免费看久爱| 亚洲精品一二区| 欧美激情精品| 亚洲三级色网| 欧美激情在线狂野欧美精品| 亚洲第一在线| 麻豆av福利av久久av| 精品69视频一区二区三区| 欧美专区在线| 国内外成人免费激情在线视频网站| 午夜精品久久久久| 国产美女精品人人做人人爽| 午夜精彩视频在线观看不卡| 国产精品女主播在线观看| 亚洲一本大道在线| 国产精品丝袜白浆摸在线| 亚洲女同同性videoxma| 国产精品毛片在线| 香蕉亚洲视频| 国产一区激情| 久久夜色撩人精品| 亚洲国产精品一区| 欧美精品三级在线观看| 一本大道久久a久久综合婷婷| 欧美日韩国产小视频在线观看| 亚洲精品系列| 欧美日韩一区在线| 亚洲午夜一区| 国内精品视频666| 免费看亚洲片| 一区二区欧美在线观看| 国产精品免费看| 亚洲专区免费| 狠狠色狠狠色综合日日五 | 蜜臀91精品一区二区三区| 伊人久久婷婷| 欧美精品二区| 亚洲特黄一级片| 国产午夜精品全部视频在线播放| 久久久一本精品99久久精品66| 极品av少妇一区二区| 欧美二区在线观看| 宅男噜噜噜66国产日韩在线观看| 国产精品私拍pans大尺度在线| 欧美伊人久久久久久午夜久久久久 | 国产伪娘ts一区| 久久狠狠婷婷| 亚洲精品免费看| 国产精品久久久久久久久果冻传媒| 性欧美video另类hd性玩具| 一区二区三区无毛| 欧美极品一区| 欧美一级免费视频| 亚洲国产一区二区三区青草影视| 欧美日一区二区在线观看| 久久精品噜噜噜成人av农村| 亚洲日本中文| 国产亚洲一级高清| 欧美日韩综合另类| 久久久久久久久久久一区| 亚洲人成艺术| 国产在线播放一区二区三区| 欧美日韩一区二区欧美激情 | 欧美国产综合| 午夜免费电影一区在线观看| 亚洲国产日韩在线| 国产精品亚洲综合久久| 欧美高清视频一区二区三区在线观看| 亚洲欧美国产日韩中文字幕| 亚洲经典自拍| 国产一区二区三区久久悠悠色av| 欧美日韩国产三级| 免费不卡中文字幕视频| 午夜一级久久| 一区二区精品在线| 91久久精品日日躁夜夜躁国产| 国产精品一区二区久久| 欧美日韩国产成人在线免费| 免费观看成人www动漫视频| 欧美尤物一区| 亚洲一区二区三区免费在线观看 | 欧美日韩免费观看一区| 久久偷窥视频| 欧美亚洲视频在线观看| 亚洲午夜激情| 这里只有精品视频在线| 在线欧美电影| 韩国一区二区在线观看| 国产毛片精品视频| 国产精品三级视频| 国产精品另类一区| 欧美日韩综合| 欧美色道久久88综合亚洲精品| 老牛影视一区二区三区| 久久九九久精品国产免费直播| 亚洲摸下面视频| 亚洲一区二区免费看| 一本色道久久综合狠狠躁篇怎么玩 | 国产精品毛片| 欧美涩涩视频| 欧美午夜激情小视频| 欧美日韩国产电影| 欧美日韩亚洲高清| 欧美国产在线电影| 欧美人与性禽动交情品| 欧美日韩精品是欧美日韩精品| 欧美精品麻豆| 欧美色视频一区| 国产精品多人| 国产精品一区在线播放| 国产精品一区二区你懂得| 国产精品一区二区久久精品| 国产精品久久看| 国产精品视频精品视频| 国产精品尤物| 国产在线精品成人一区二区三区 | 99精品久久免费看蜜臀剧情介绍| 亚洲欧洲日夜超级视频| 亚洲精品网址在线观看| 日韩亚洲视频| 亚洲综合三区| 久久精品免费电影| 久久综合999| 欧美成人网在线| 欧美日韩国产一区二区三区地区 | 欧美 日韩 国产一区二区在线视频 | 国产一区二区丝袜高跟鞋图片 | 国产精品国产馆在线真实露脸| 欧美人妖在线观看| 欧美三级乱人伦电影| 国产精品一香蕉国产线看观看 | 亚洲美女一区| 亚洲色在线视频| 亚洲欧美一区二区三区极速播放 | 欧美肥婆在线| 欧美激情中文字幕一区二区 | 一本久久青青| 国产精品嫩草99av在线| 激情亚洲成人| 99精品国产福利在线观看免费 | 亚洲精品免费一二三区| 亚洲最新视频在线| 欧美一区二区高清在线观看| 久久久久久久久久久成人| 欧美国产日韩一二三区| 国产精品a久久久久| 国产综合色产| av成人免费观看| 欧美一区二区私人影院日本 | 国产精品美女久久久久久免费| 国产欧美在线播放| 亚洲激情视频在线| 欧美一级片一区| 欧美精品一区二区三区久久久竹菊| 国产精品人成在线观看免费 | 999亚洲国产精| 欧美影院视频| 欧美日韩国产麻豆| 国产自产2019最新不卡| 日韩亚洲精品在线| 欧美主播一区二区三区| 免费精品99久久国产综合精品| 欧美午夜免费电影| 亚洲激情社区| 久久精品综合网|