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

主頁(yè) > 知識(shí)庫(kù) > MySQL 連接查詢(xún)的原理和應(yīng)用

MySQL 連接查詢(xún)的原理和應(yīng)用

熱門(mén)標(biāo)簽:芒果電話(huà)機(jī)器人自動(dòng)化 申請(qǐng)外呼電話(huà)線路 信陽(yáng)穩(wěn)定外呼系統(tǒng)運(yùn)營(yíng)商 湖南人工外呼系統(tǒng)多少錢(qián) 廣東人工電話(huà)機(jī)器人 百度地圖圖標(biāo)標(biāo)注中心 日照旅游地圖標(biāo)注 石家莊電商外呼系統(tǒng) 南通自動(dòng)外呼系統(tǒng)軟件

概述

MySQL最強(qiáng)大的功能之一就是能在數(shù)據(jù)檢索的執(zhí)行中連接(join)表。大部分的單表數(shù)據(jù)查詢(xún)并不能滿(mǎn)足我們的需求,這時(shí)候我們就需要連接一個(gè)或者多個(gè)表,并通過(guò)一些條件過(guò)濾篩選出我們需要的數(shù)據(jù)。

了解MySQL連接查詢(xún)之前我們先來(lái)理解下笛卡爾積的原理。

數(shù)據(jù)準(zhǔn)備

依舊使用上節(jié)的表數(shù)據(jù)(包含classes 班級(jí)表和students 學(xué)生表):

mysql> select * from classes;
+---------+-----------+
| classid | classname |
+---------+-----------+
|    1 | 初三一班 |
|    2 | 初三二班 |
|    3 | 初三三班 |
|    4 | 初三四班 |
+---------+-----------+
4 rows in set

mysql> select * from students;
+-----------+-------------+-------+---------+
| studentid | studentname | score | classid |
+-----------+-------------+-------+---------+
|     1 | brand    | 97.5 |    1 |
|     2 | helen    | 96.5 |    1 |
|     3 | lyn     | 96  |    1 |
|     4 | sol     | 97  |    1 |
|     7 | b1     | 81  |    2 |
|     8 | b2     | 82  |    2 |
|    13 | c1     | 71  |    3 |
|    14 | c2     | 72.5 |    3 |
|    19 | lala    | 51  |    0 |
+-----------+-------------+-------+---------+
9 rows in set

笛卡爾積

笛卡爾積:也就是笛卡爾乘積,假設(shè)兩個(gè)集合A和B,笛卡爾積表示A集合中的元素和B集合中的元素任意相互關(guān)聯(lián)產(chǎn)生的所有可能的結(jié)果。

比如A中有m個(gè)元素,B中有n個(gè)元素,A、B笛卡爾積產(chǎn)生的結(jié)果有m*n個(gè)結(jié)果,相當(dāng)于循環(huán)遍歷兩個(gè)集合中的元素,任意組合。

笛卡爾積在SQL中的實(shí)現(xiàn)方式既是交叉連接(Cross Join)。所有連接方式都會(huì)先生成臨時(shí)笛卡爾積表,笛卡爾積是關(guān)系代數(shù)里的一個(gè)概念,表示兩個(gè)表中的每一行數(shù)據(jù)任意組合。

所以上面的表就是 4(班級(jí)表)* 9(學(xué)生表) = 36條數(shù)據(jù);

笛卡爾積語(yǔ)法格式:

 select cname1,cname2,... from tname1,tname2,...;
 or
 select cname from tname1 join tname2 [join tname...];

圖例表示:

上述兩個(gè)表實(shí)際執(zhí)行結(jié)果如下:

mysql> select * from classes a,students b order by a.classid,b.studentid;
+---------+-----------+-----------+-------------+-------+---------+
| classid | classname | studentid | studentname | score | classid |
+---------+-----------+-----------+-------------+-------+---------+
|    1 | 初三一班 |     1 | brand    | 97.5 |    1 |
|    1 | 初三一班 |     2 | helen    | 96.5 |    1 |
|    1 | 初三一班 |     3 | lyn     | 96  |    1 |
|    1 | 初三一班 |     4 | sol     | 97  |    1 |
|    1 | 初三一班 |     7 | b1     | 81  |    2 |
|    1 | 初三一班 |     8 | b2     | 82  |    2 |
|    1 | 初三一班 |    13 | c1     | 71  |    3 |
|    1 | 初三一班 |    14 | c2     | 72.5 |    3 |
|    1 | 初三一班 |    19 | lala    | 51  |    0 |
|    2 | 初三二班 |     1 | brand    | 97.5 |    1 |
|    2 | 初三二班 |     2 | helen    | 96.5 |    1 |
|    2 | 初三二班 |     3 | lyn     | 96  |    1 |
|    2 | 初三二班 |     4 | sol     | 97  |    1 |
|    2 | 初三二班 |     7 | b1     | 81  |    2 |
|    2 | 初三二班 |     8 | b2     | 82  |    2 |
|    2 | 初三二班 |    13 | c1     | 71  |    3 |
|    2 | 初三二班 |    14 | c2     | 72.5 |    3 |
|    2 | 初三二班 |    19 | lala    | 51  |    0 |
|    3 | 初三三班 |     1 | brand    | 97.5 |    1 |
|    3 | 初三三班 |     2 | helen    | 96.5 |    1 |
|    3 | 初三三班 |     3 | lyn     | 96  |    1 |
|    3 | 初三三班 |     4 | sol     | 97  |    1 |
|    3 | 初三三班 |     7 | b1     | 81  |    2 |
|    3 | 初三三班 |     8 | b2     | 82  |    2 |
|    3 | 初三三班 |    13 | c1     | 71  |    3 |
|    3 | 初三三班 |    14 | c2     | 72.5 |    3 |
|    3 | 初三三班 |    19 | lala    | 51  |    0 |
|    4 | 初三四班 |     1 | brand    | 97.5 |    1 |
|    4 | 初三四班 |     2 | helen    | 96.5 |    1 |
|    4 | 初三四班 |     3 | lyn     | 96  |    1 |
|    4 | 初三四班 |     4 | sol     | 97  |    1 |
|    4 | 初三四班 |     7 | b1     | 81  |    2 |
|    4 | 初三四班 |     8 | b2     | 82  |    2 |
|    4 | 初三四班 |    13 | c1     | 71  |    3 |
|    4 | 初三四班 |    14 | c2     | 72.5 |    3 |
|    4 | 初三四班 |    19 | lala    | 51  |    0 |
+---------+-----------+-----------+-------------+-------+---------+
36 rows in set

這樣的數(shù)據(jù)肯定不是我們想要的,在實(shí)際應(yīng)用中,表連接時(shí)要加上限制條件,才能夠篩選出我們真正需要的數(shù)據(jù)。

我們主要的連接查詢(xún)有這幾種:內(nèi)連接、左(外)連接、右(外)連接,下面我們一 一來(lái)看。

內(nèi)連接查詢(xún) inner join

語(yǔ)法格式:

 select cname from tname1 inner join tname2 on join condition;
 或者
 select cname from tname1 join tname2 on join condition;
 或者
 select cname from tname1,tname2 [where join condition];

說(shuō)明:在笛卡爾積的基礎(chǔ)上加上了連接條件,組合兩個(gè)表,返回符合連接條件的記錄,也就是返回兩個(gè)表的交集(陰影)部分。如果沒(méi)有加上這個(gè)連接條件,就是上面笛卡爾積的結(jié)果。

mysql> select a.classname,b.studentname,b.score from classes a inner join students b on a.classid = b.classid;
+-----------+-------------+-------+
| classname | studentname | score |
+-----------+-------------+-------+
| 初三一班 | brand    | 97.5 |
| 初三一班 | helen    | 96.5 |
| 初三一班 | lyn     | 96  |
| 初三一班 | sol     | 97  |
| 初三二班 | b1     | 81  |
| 初三二班 | b2     | 82  |
| 初三三班 | c1     | 71  |
| 初三三班 | c2     | 72.5 |
+-----------+-------------+-------+
8 rows in set

從上面的數(shù)據(jù)可以看出 ,初三四班 classid = 4,因?yàn)闆](méi)有關(guān)聯(lián)的學(xué)生,所以被過(guò)濾掉了;lala 同學(xué)的classid=0,沒(méi)法關(guān)聯(lián)到具體的班級(jí),也被過(guò)濾掉了,只取兩表都有的數(shù)據(jù)交集

mysql> select a.classname,b.studentname,b.score from classes a,students b where a.classid = b.classid and a.classid=1;
+-----------+-------------+-------+
| classname | studentname | score |
+-----------+-------------+-------+
| 初三一班 | brand    | 97.5 |
| 初三一班 | helen    | 96.5 |
| 初三一班 | lyn     | 96  |
| 初三一班 | sol     | 97  |
+-----------+-------------+-------+
4 rows in set

查找1班同學(xué)的成績(jī)信息,上面語(yǔ)法格式的第三種,這種方式簡(jiǎn)潔高效,直接在連接查詢(xún)的結(jié)果后面進(jìn)行Where條件篩選。 

左連接查詢(xún) left join

left join on / left outer join on,語(yǔ)法格式:

select cname from tname1 left join tname2 on join condition;

說(shuō)明: left join 是left outer join的簡(jiǎn)寫(xiě),全稱(chēng)是左外連接,外連接中的一種。 左(外)連接,左表(classes)的記錄將會(huì)全部出來(lái),而右表(students)只會(huì)顯示符合搜索條件的記錄。右表無(wú)法關(guān)聯(lián)的內(nèi)容均為null。

mysql> select a.classname,b.studentname,b.score from classes a left join students b on a.classid = b.classid;
+-----------+-------------+-------+
| classname | studentname | score |
+-----------+-------------+-------+
| 初三一班 | brand    | 97.5 |
| 初三一班 | helen    | 96.5 |
| 初三一班 | lyn     | 96  |
| 初三一班 | sol     | 97  |
| 初三二班 | b1     | 81  |
| 初三二班 | b2     | 82  |
| 初三三班 | c1     | 71  |
| 初三三班 | c2     | 72.5 |
| 初三四班 | NULL    | NULL |
+-----------+-------------+-------+
9 rows in set

從上面結(jié)果中可以看出,初三四班無(wú)法找到對(duì)應(yīng)的學(xué)生,所以后面兩個(gè)字段使用null標(biāo)識(shí)。 

右連接查詢(xún) right join

right join on / right outer join on,語(yǔ)法格式:

select cname from tname1 right join tname2 on join condition;

說(shuō)明:right join是right outer join的簡(jiǎn)寫(xiě),全稱(chēng)是右外連接,外連接中的一種。與左(外)連接相反,右(外)連接,左表(classes)只會(huì)顯示符合搜索條件的記錄,而右表(students)的記錄將會(huì)全部表示出來(lái)。左表記錄不足的地方均為NULL。 

mysql> select a.classname,b.studentname,b.score from classes a right join students b on a.classid = b.classid;
+-----------+-------------+-------+
| classname | studentname | score |
+-----------+-------------+-------+
| 初三一班 | brand    | 97.5 |
| 初三一班 | helen    | 96.5 |
| 初三一班 | lyn     | 96  |
| 初三一班 | sol     | 97  |
| 初三二班 | b1     | 81  |
| 初三二班 | b2     | 82  |
| 初三三班 | c1     | 71  |
| 初三三班 | c2     | 72.5 |
| NULL   | lala    | 51  |
+-----------+-------------+-------+
9 rows in set

從上面結(jié)果中可以看出,lala同學(xué)無(wú)法找到班級(jí),所以班級(jí)名稱(chēng)字段為null。  

連接查詢(xún)+聚合函數(shù)

使用連接查詢(xún)的時(shí)候,經(jīng)常會(huì)配合使用聚集函數(shù)來(lái)進(jìn)行數(shù)據(jù)匯總。比如在上面的數(shù)據(jù)基礎(chǔ)上查詢(xún)出每個(gè)班級(jí)的人數(shù)和平均分?jǐn)?shù)、班級(jí)總分?jǐn)?shù)。

mysql> select a.classname as '班級(jí)名稱(chēng)',count(b.studentid) as '總?cè)藬?shù)',sum(b.score) as '總分',avg(b.score) as '平均分'
from classes a inner join students b on a.classid = b.classid
group by a.classid,a.classname;
+----------+--------+--------+-----------+
| 班級(jí)名稱(chēng) | 總?cè)藬?shù) | 總分  | 平均分  |
+----------+--------+--------+-----------+
| 初三一班 |   4 | 387.00 | 96.750000 |
| 初三二班 |   2 | 163.00 | 81.500000 |
| 初三三班 |   2 | 143.50 | 71.750000 |
+----------+--------+--------+-----------+
3 rows in set

這邊連表查詢(xún)的同時(shí)對(duì)班級(jí)(classid,classname)做了分組,并輸出每個(gè)班級(jí)的人數(shù)、平均分、班級(jí)總分。

連接查詢(xún)附加過(guò)濾條件

使用連接查詢(xún)之后,大概率會(huì)對(duì)數(shù)據(jù)進(jìn)行在過(guò)濾篩選,所以我們可以在連接查詢(xún)之后再加上where條件,比如我們根據(jù)上述的結(jié)果只取出一班的同學(xué)信息。

mysql> select a.classname,b.studentname,b.score from classes a inner join students b on a.classid = b.classid where a.classid=1;
+-----------+-------------+-------+
| classname | studentname | score |
+-----------+-------------+-------+
| 初三一班 | brand    | 97.5 |
| 初三一班 | helen    | 96.5 |
| 初三一班 | lyn     | 96  |
| 初三一班 | sol     | 97  |
+-----------+-------------+-------+
4 rows in set

如上,只輸出一班的同學(xué),同理,可以附件 limit 限制,order by排序等操作。

總結(jié)

1、連接查詢(xún)必然要帶上連接條件,否則會(huì)變成笛卡爾乘積數(shù)據(jù),使用不正確的聯(lián)結(jié)條件,也將返回不正確的數(shù)據(jù)。

2、SQL規(guī)范推薦首選INNER JOIN語(yǔ)法。但是連接的幾種方式本身并沒(méi)有明顯的性能差距,性能的差距主要是由數(shù)據(jù)的結(jié)構(gòu)、連接的條件,索引的使用等多種條件綜合決定的。

我們應(yīng)該根據(jù)實(shí)際的業(yè)務(wù)場(chǎng)景來(lái)決定,比如上述數(shù)據(jù)場(chǎng)景:如果要求返回返回有學(xué)生的班級(jí)就使用 inner join;如果必須輸出所有班級(jí)則使用left join;如果必須輸出所有學(xué)生,則使用right join。

3、性能上的考慮,MySQL在運(yùn)行時(shí)會(huì)根據(jù)關(guān)聯(lián)條件處理連接的表,這種處理可能是非常耗費(fèi)資源的,連接的表越多,性能下降越厲害。所以要分析去除那些不必要的連接和不需要顯示的字段。

之前我的項(xiàng)目團(tuán)隊(duì)在優(yōu)化舊的業(yè)務(wù)代碼時(shí),發(fā)現(xiàn)隨著業(yè)務(wù)的變更,某些數(shù)據(jù)不需要顯示,對(duì)應(yīng)的某個(gè)連接也不需要了,去掉之后,性能較大提升。

以上就是MySQL 連接查詢(xún)的原理和應(yīng)用的詳細(xì)內(nèi)容,更多關(guān)于MySQL 連接查詢(xún)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • php7連接MySQL實(shí)現(xiàn)簡(jiǎn)易查詢(xún)程序的方法
  • Mysql join連接查詢(xún)的語(yǔ)法與示例
  • mysql連接查詢(xún)、聯(lián)合查詢(xún)、子查詢(xún)?cè)砼c用法實(shí)例詳解
  • MySQL利用UNION連接2個(gè)查詢(xún)排序失效詳解
  • python針對(duì)mysql數(shù)據(jù)庫(kù)的連接、查詢(xún)、更新、刪除操作示例
  • Mysql自連接查詢(xún)實(shí)例詳解
  • 詳解MySQL數(shù)據(jù)庫(kù)--多表查詢(xún)--內(nèi)連接,外連接,子查詢(xún),相關(guān)子查詢(xún)
  • mysql多表連接查詢(xún)實(shí)例講解
  • mysql多個(gè)left join連接查詢(xún)用法分析
  • JDBC連接MySql數(shù)據(jù)庫(kù)步驟 以及查詢(xún)、插入、刪除、更新等
  • mysql連接查詢(xún)(左連接,右連接,內(nèi)連接)

標(biāo)簽:牡丹江 公主嶺 惠州 合肥 天津 阿里 沈陽(yáng) 呼和浩特

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL 連接查詢(xún)的原理和應(yīng)用》,本文關(guān)鍵詞  MySQL,連接,查詢(xú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 連接查詢(xún)的原理和應(yīng)用》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于MySQL 連接查詢(xún)的原理和應(yīng)用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美国产一区在线| 日韩一区二区三区在线| 欧美v国产在线一区二区三区| 亚洲欧美激情视频在线观看一区二区三区| 欧美精品亚洲二区| 日韩av电影免费观看高清完整版 | 久久国产乱子精品免费女| 在线观看国产日韩| 日日欢夜夜爽一区| 6080午夜不卡| 欧美aaaaa成人免费观看视频| 开心九九激情九九欧美日韩精美视频电影| 日韩精品欧美精品| 欧美精品一区二区三区四区 | 国产精品一区一区| 国产精品久久久久久户外露出| 亚洲卡通动漫在线| 精品国产人成亚洲区| 欧美中文字幕久久| 精品入口麻豆88视频| 成人精品免费视频| 亚洲大片一区二区三区| 亚洲精品乱码久久久久久久久 | 国产jizzjizz一区二区| 国产丶欧美丶日本不卡视频| 91在线看国产| 国产精品视频免费| 日本色综合中文字幕| 狠狠色狠狠色综合系列| 色婷婷激情综合| 精品88久久久久88久久久| 精品少妇一区二区三区视频免付费| av亚洲精华国产精华精华| 精品久久久久久久久久久久久久久久久 | 日韩欧美在线影院| 亚洲午夜在线电影| 国产不卡免费视频| 国产欧美日本一区视频| 麻豆精品久久久| 在线观看日韩一区| 日韩在线一区二区三区| 欧美v日韩v国产v| 成人精品国产免费网站| 国产精品福利影院| 色网站国产精品| 亚洲一二三四久久| 色狠狠综合天天综合综合| 一区二区三区四区视频精品免费| 国产亚洲一二三区| 97久久超碰国产精品电影| 亚洲人成在线观看一区二区| 成人免费看片app下载| 亚洲一区二区在线免费观看视频 | 亚洲成人av电影| 欧美日韩一区国产| 国产精品一区免费视频| 久久久久久免费| 欧美视频在线播放| 加勒比av一区二区| 欧美一区二区三区视频在线观看| 91精品在线观看入口| 三级精品在线观看| 精品日韩一区二区| 91香蕉视频黄| 麻豆freexxxx性91精品| 中文字幕亚洲视频| 日韩一区二区电影| 精品视频在线看| 91首页免费视频| 亚洲激情自拍偷拍| 亚洲欧美在线另类| 欧美精品日韩一本| 亚洲精品一线二线三线| 欧美片网站yy| 欧美又粗又大又爽| 成人精品免费网站| 国内精品写真在线观看| 玖玖九九国产精品| 国产一区二区三区免费观看| 免费成人深夜小野草| 秋霞午夜鲁丝一区二区老狼| 亚洲高清在线精品| 天涯成人国产亚洲精品一区av| 欧美视频一二三区| 欧美在线免费观看视频| 欧美手机在线视频| 日韩欧美久久久| 中文av一区特黄| 一区二区三区在线免费播放| 天堂av在线一区| 成人高清免费观看| 538在线一区二区精品国产| 欧美大片一区二区三区| 一区二区三区高清| 国产在线日韩欧美| 91丨国产丨九色丨pron| 日韩三区在线观看| 亚洲乱码国产乱码精品精98午夜| 色哟哟国产精品| 91精品国产综合久久香蕉的特点| 国产成人精品免费在线| 97国产一区二区| 日韩视频在线观看一区二区| 亚洲欧美日韩中文播放| 国产一区二三区好的| 日韩欧美国产午夜精品| 亚洲精品国产高清久久伦理二区| 国产精品美女久久久久久久久| 久久这里只有精品视频网| 国产欧美日韩视频一区二区| 日韩精品视频网站| 欧亚洲嫩模精品一区三区| 国产日本欧洲亚洲| 国产成人午夜片在线观看高清观看| 精品一区二区免费视频| 日本丶国产丶欧美色综合| 综合网在线视频| 欧美色视频一区| 亚洲在线视频免费观看| 欧美综合一区二区| 日韩中文字幕区一区有砖一区 | 成人精品国产一区二区4080| 精品国产一区二区三区忘忧草| 欧美另类变人与禽xxxxx| 亚洲一级二级三级| 欧美美女一区二区在线观看| 国产日韩av一区| av电影在线不卡| 亚洲一区二区三区四区的| 日本一区二区三区国色天香| 成人av综合一区| 中文字幕一区二区三区蜜月| 国产成人免费视频网站| 亚洲日本免费电影| 欧美天天综合网| 国产成人夜色高潮福利影视| 久久午夜国产精品| 丁香婷婷综合激情五月色| 欧美aⅴ一区二区三区视频| 欧美一级片免费看| 欧美一区二区三区四区视频| 日本美女一区二区三区视频| 久久蜜桃av一区二区天堂| www.66久久| 国产一区二区精品久久| 亚洲国产视频在线| 日本一区二区三级电影在线观看 | 在线欧美日韩国产| 五月天激情综合网| 国产欧美一区二区三区在线老狼| 国产婷婷色一区二区三区四区| 精品少妇一区二区| 成人一区二区三区视频在线观看 | 国产精品久久久久久久久免费相片| 国产精品婷婷午夜在线观看| 91精品国产综合久久福利| 欧美专区日韩专区| 欧洲一区二区av| 欧洲在线/亚洲| 欧美色倩网站大全免费| 色偷偷久久一区二区三区| 国产精品77777竹菊影视小说| 欧美又粗又大又爽| 色综合色综合色综合色综合色综合| 欧美一级淫片007| 欧美一区二区三区免费视频| 欧美日韩成人综合天天影院| 欧美美女网站色| 久久久综合网站| 成人免费在线视频| 婷婷丁香激情综合| 精品亚洲免费视频| 国产99精品国产| av中文字幕不卡| 欧美专区在线观看一区| 91国模大尺度私拍在线视频| 色嗨嗨av一区二区三区| 日韩片之四级片| 中文一区二区在线观看| 亚洲最大成人综合| 国产在线日韩欧美| 91美女视频网站| 日韩亚洲欧美在线观看| 亚洲同性同志一二三专区| 亚洲一区二区av在线| 国产一区二区剧情av在线| 色综合夜色一区| 精品福利一区二区三区 | 日本不卡视频在线| 国产成人av影院| 欧美日产在线观看| 国产精品免费免费| 老汉av免费一区二区三区 | 国产在线精品免费av| 成人听书哪个软件好| 精品国产乱码久久久久久久| 亚洲一区二区三区四区在线 | 国产欧美精品国产国产专区| 欧美激情在线观看视频免费| 日本aⅴ免费视频一区二区三区|