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

MySQL數(shù)據(jù)庫(kù)連接查詢?join原理

 更新時(shí)間:2022年06月08日 09:09:26   作者:彭世瑜  
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)連接查詢?join原理,文章首先通過(guò)將多張表連到一起查詢?導(dǎo)致記錄行數(shù)和字段列發(fā)生變化,利用一對(duì)一、一對(duì)多和多對(duì)多關(guān)系保證數(shù)據(jù)完整性展開(kāi)主題內(nèi)容,需要的小伙伴可以參考一下

1、連接查詢的分類

  • 交叉連接
  • 內(nèi)連接
  • 外連接
    • 左外鏈接(左連接)
    • 右外連接(右連接)
  • 自然連接

2、交叉連接

將兩張表的數(shù)據(jù)與另外一張表彼此交叉

2.1、原理

笛卡爾積:

  • 從第一張表一次取出每一條數(shù)據(jù)
  • 取出每一條記錄之后,與另外一張表的全部記錄挨個(gè)匹配
  • 沒(méi)有任何匹配條件,所有的結(jié)果都會(huì)保留
  • 記錄數(shù)=第一張表記錄數(shù) * 第二張表記錄數(shù)
  • 字段數(shù) = 第一張表字段數(shù) + 第二章表字段數(shù)

2.2、基本語(yǔ)法

表1 cross join 表2;
mysql> select * from tb_teacher;
+--------+------+
| name   | age  |
+--------+------+
| Jack   |   24 |
| Tom    |   26 |
| Steve  | NULL |
| 張三   |   23 |
| 張三   |   23 |
+--------+------+
5 rows in set (0.00 sec)

mysql> select * from my_student;
+----+--------+----------+------+--------+
| id | name   | class_id | age  | gender |
+----+--------+----------+------+--------+
|  1 | 劉備   |        1 |   18 |      2 |
|  2 | 李四   |        1 |   19 |      1 |
|  3 | 王五   |        2 |   20 |      2 |
|  7 | 張飛   |        2 |   21 |      1 |
|  8 | 關(guān)羽   |        1 |   22 |      2 |
|  9 | 曹操   |        1 |   20 |   NULL |
+----+--------+----------+------+--------+
6 rows in set (0.01 sec)

mysql> select * from my_student cross join tb_teacher;
+----+--------+----------+------+--------+--------+------+
| id | name   | class_id | age  | gender | name   | age  |
+----+--------+----------+------+--------+--------+------+
|  1 | 劉備   |        1 |   18 |      2 | Jack   |   24 |
|  1 | 劉備   |        1 |   18 |      2 | Tom    |   26 |
|  1 | 劉備   |        1 |   18 |      2 | Steve  | NULL |
|  1 | 劉備   |        1 |   18 |      2 | 張三   |   23 |
|  1 | 劉備   |        1 |   18 |      2 | 張三   |   23 |
|  2 | 李四   |        1 |   19 |      1 | Jack   |   24 |
|  2 | 李四   |        1 |   19 |      1 | Tom    |   26 |
|  2 | 李四   |        1 |   19 |      1 | Steve  | NULL |
|  2 | 李四   |        1 |   19 |      1 | 張三   |   23 |
|  2 | 李四   |        1 |   19 |      1 | 張三   |   23 |
|  3 | 王五   |        2 |   20 |      2 | Jack   |   24 |
|  3 | 王五   |        2 |   20 |      2 | Tom    |   26 |
|  3 | 王五   |        2 |   20 |      2 | Steve  | NULL |
|  3 | 王五   |        2 |   20 |      2 | 張三   |   23 |
|  3 | 王五   |        2 |   20 |      2 | 張三   |   23 |
|  7 | 張飛   |        2 |   21 |      1 | Jack   |   24 |
|  7 | 張飛   |        2 |   21 |      1 | Tom    |   26 |
|  7 | 張飛   |        2 |   21 |      1 | Steve  | NULL |
|  7 | 張飛   |        2 |   21 |      1 | 張三   |   23 |
|  7 | 張飛   |        2 |   21 |      1 | 張三   |   23 |
|  8 | 關(guān)羽   |        1 |   22 |      2 | Jack   |   24 |
|  8 | 關(guān)羽   |        1 |   22 |      2 | Tom    |   26 |
|  8 | 關(guān)羽   |        1 |   22 |      2 | Steve  | NULL |
|  8 | 關(guān)羽   |        1 |   22 |      2 | 張三   |   23 |
|  8 | 關(guān)羽   |        1 |   22 |      2 | 張三   |   23 |
|  9 | 曹操   |        1 |   20 |   NULL | Jack   |   24 |
|  9 | 曹操   |        1 |   20 |   NULL | Tom    |   26 |
|  9 | 曹操   |        1 |   20 |   NULL | Steve  | NULL |
|  9 | 曹操   |        1 |   20 |   NULL | 張三   |   23 |
|  9 | 曹操   |        1 |   20 |   NULL | 張三   |   23 |
+----+--------+----------+------+--------+--------+------+
30 rows in set (0.00 sec)

2.3、應(yīng)用

基本沒(méi)有實(shí)際意義

等價(jià)于

select * from my_student, tb_teacher;

3、內(nèi)連接

從一張表中取出所有的記錄,去另外一張表中匹配,利用匹配條件進(jìn)行匹配,成功則保留,失敗則放棄

3.1、原理

  • 從第一張表中取出一條記錄,然后去另外一張表中進(jìn)行匹配
  • 利用匹配條件進(jìn)行匹配
  • 匹配到則保留,繼續(xù)向下匹配
  • 匹配失敗則放棄

3.2、基本語(yǔ)法

表1 inner join 表2 on 匹配條件
create table my_class(
    id int primary key auto_increment,
    name varchar(10) not null
);

insert into my_class (name) values ('一班'), ('二班');

mysql> select * from my_class;
+----+--------+
| id | name   |
+----+--------+
|  1 | 一班   |
|  2 | 二班   |
+----+--------+

mysql> select * from my_student;
+----+--------+----------+------+--------+
| id | name   | class_id | age  | gender |
+----+--------+----------+------+--------+
|  1 | 劉備   |        1 |   18 |      2 |
|  2 | 李四   |        1 |   19 |      1 |
|  3 | 王五   |        2 |   20 |      2 |
|  4 | 張飛   |        2 |   21 |      1 |
|  5 | 關(guān)羽   |        1 |   22 |      2 |
|  6 | 曹操   |        1 |   20 |   NULL |
+----+--------+----------+------+--------+

-- 如果內(nèi)連接沒(méi)有條件,其實(shí)就是交叉連接(笛卡爾積)
mysql> select * from my_student inner join my_class;
+----+--------+----------+------+--------+----+--------+
| id | name   | class_id | age  | gender | id | name   |
+----+--------+----------+------+--------+----+--------+
|  1 | 劉備   |        1 |   18 |      2 |  1 | 一班   |
|  1 | 劉備   |        1 |   18 |      2 |  2 | 二班   |
|  2 | 李四   |        1 |   19 |      1 |  1 | 一班   |
|  2 | 李四   |        1 |   19 |      1 |  2 | 二班   |
|  3 | 王五   |        2 |   20 |      2 |  1 | 一班   |
|  3 | 王五   |        2 |   20 |      2 |  2 | 二班   |
|  4 | 張飛   |        2 |   21 |      1 |  1 | 一班   |
|  4 | 張飛   |        2 |   21 |      1 |  2 | 二班   |
|  5 | 關(guān)羽   |        1 |   22 |      2 |  1 | 一班   |
|  5 | 關(guān)羽   |        1 |   22 |      2 |  2 | 二班   |
|  6 | 曹操   |        1 |   20 |   NULL |  1 | 一班   |
|  6 | 曹操   |        1 |   20 |   NULL |  2 | 二班   |
+----+--------+----------+------+--------+----+--------+
12 rows in set (0.00 sec)

-- 表的設(shè)計(jì),通常會(huì)有同名字段,通常使用`表名.字段`來(lái)保證唯一性
mysql> select * from my_student inner join my_class on my_student.class_id = my_class.id;
+----+--------+----------+------+--------+----+--------+
| id | name   | class_id | age  | gender | id | name   |
+----+--------+----------+------+--------+----+--------+
|  1 | 劉備   |        1 |   18 |      2 |  1 | 一班   |
|  2 | 李四   |        1 |   19 |      1 |  1 | 一班   |
|  3 | 王五   |        2 |   20 |      2 |  2 | 二班   |
|  4 | 張飛   |        2 |   21 |      1 |  2 | 二班   |
|  5 | 關(guān)羽   |        1 |   22 |      2 |  1 | 一班   |
|  6 | 曹操   |        1 |   20 |   NULL |  1 | 一班   |
+----+--------+----------+------+--------+----+--------+

-- 如果表名比較長(zhǎng),可以使用別名簡(jiǎn)化
mysql> select * from my_student as a inner join my_class b on a.class_id = b.id;
+----+--------+----------+------+--------+----+--------+
| id | name   | class_id | age  | gender | id | name   |
+----+--------+----------+------+--------+----+--------+
|  1 | 劉備   |        1 |   18 |      2 |  1 | 一班   |
|  2 | 李四   |        1 |   19 |      1 |  1 | 一班   |
|  3 | 王五   |        2 |   20 |      2 |  2 | 二班   |
|  4 | 張飛   |        2 |   21 |      1 |  2 | 二班   |
|  5 | 關(guān)羽   |        1 |   22 |      2 |  1 | 一班   |
|  6 | 曹操   |        1 |   20 |   NULL |  1 | 一班   |
+----+--------+----------+------+--------+----+--------+

-- 可以交換兩張表的先后順序
mysql> select * from my_class b inner join my_student as a on a.class_id = b.id;
+----+--------+----+--------+----------+------+--------+
| id | name   | id | name   | class_id | age  | gender |
+----+--------+----+--------+----------+------+--------+
|  1 | 一班   |  1 | 劉備   |        1 |   18 |      2 |
|  1 | 一班   |  2 | 李四   |        1 |   19 |      1 |
|  2 | 二班   |  3 | 王五   |        2 |   20 |      2 |
|  2 | 二班   |  4 | 張飛   |        2 |   21 |      1 |
|  1 | 一班   |  5 | 關(guān)羽   |        1 |   22 |      2 |
|  1 | 一班   |  6 | 曹操   |        1 |   20 |   NULL |
+----+--------+----+--------+----------+------+--------+

-- on 可以使用 where 替換,推薦使用 on
mysql> select * from my_class b inner join my_student as a where a.class_id = b.id;
+----+--------+----+--------+----------+------+--------+
| id | name   | id | name   | class_id | age  | gender |
+----+--------+----+--------+----------+------+--------+
|  1 | 一班   |  1 | 劉備   |        1 |   18 |      2 |
|  1 | 一班   |  2 | 李四   |        1 |   19 |      1 |
|  2 | 二班   |  3 | 王五   |        2 |   20 |      2 |
|  2 | 二班   |  4 | 張飛   |        2 |   21 |      1 |
|  1 | 一班   |  5 | 關(guān)羽   |        1 |   22 |      2 |
|  1 | 一班   |  6 | 曹操   |        1 |   20 |   NULL |
+----+--------+----+--------+----------+------+--------+

3.3、應(yīng)用

內(nèi)連接通常是在對(duì)數(shù)據(jù)有精確要求的地方使用,必須保證兩張表中都能進(jìn)行數(shù)據(jù)匹配,內(nèi)連接匹配到才會(huì)保存

4、外連接

按照某一張表作為主表(表中所有記錄在最后都會(huì)保留)根據(jù)條件取連接另外一張表,從而得到目標(biāo)數(shù)據(jù)

外連接分為兩種:

  • 左連接:左表是主表
  • 右連接:右表是主表

4.1、原理

  • 確定主表,左連接就是左邊的表為主表,右連接就是右邊的表為主表
  • 拿主表的每一條記錄,去匹配另外的一張表(從表)的每一條記錄
  • 如果滿足匹配條件,保留,不滿足即不保留
  • 如果主表記錄在從表中一條都沒(méi)有匹配成功,那么也要保留記錄, 從表對(duì)應(yīng)的字段值都是null

4.2、基本語(yǔ)法

-- 左連接
主表 left join 從表 on 連接條件;
-- 右連接
從表 right join 主表 on 連接條件;

左表的數(shù)據(jù)在前,右表的數(shù)據(jù)在后

mysql> select * from my_student;
+----+--------+----------+------+--------+
| id | name   | class_id | age  | gender |
+----+--------+----------+------+--------+
|  1 | 劉備   |        1 |   18 |      2 |
|  2 | 李四   |        1 |   19 |      1 |
|  3 | 王五   |        2 |   20 |      2 |
|  4 | 張飛   |        2 |   21 |      1 |
|  5 | 關(guān)羽   |        1 |   22 |      2 |
|  6 | 曹操   |        1 |   20 |   NULL |
+----+--------+----------+------+--------+
mysql> select * from my_class;
+----+--------+
| id | name   |
+----+--------+
|  1 | 一班   |
|  3 | 三班   |
|  2 | 二班   |
+----+--------+
mysql> select * from my_student as s left join my_class c on s.class_id = c.id;
+----+--------+----------+------+--------+------+--------+
| id | name   | class_id | age  | gender | id   | name   |
+----+--------+----------+------+--------+------+--------+
|  1 | 劉備   |        1 |   18 |      2 |    1 | 一班   |
|  2 | 李四   |        1 |   19 |      1 |    1 | 一班   |
|  3 | 王五   |        2 |   20 |      2 |    2 | 二班   |
|  4 | 張飛   |        2 |   21 |      1 |    2 | 二班   |
|  5 | 關(guān)羽   |        1 |   22 |      2 |    1 | 一班   |
|  6 | 曹操   |        1 |   20 |   NULL |    1 | 一班   |
+----+--------+----------+------+--------+------+--------+
select * from my_student as s right join my_class c on s.class_id = c.id;
mysql> select * from my_student as s right join my_class c on s.class_id = c.id;
+------+--------+----------+------+--------+----+--------+
| id   | name   | class_id | age  | gender | id | name   |
+------+--------+----------+------+--------+----+--------+
|    1 | 劉備   |        1 |   18 |      2 |  1 | 一班   |
|    2 | 李四   |        1 |   19 |      1 |  1 | 一班   |
|    3 | 王五   |        2 |   20 |      2 |  2 | 二班   |
|    4 | 張飛   |        2 |   21 |      1 |  2 | 二班   |
|    5 | 關(guān)羽   |        1 |   22 |      2 |  1 | 一班   |
|    6 | 曹操   |        1 |   20 |   NULL |  1 | 一班   |
| NULL | NULL   |     NULL | NULL |   NULL |  3 | 三班   |
+------+--------+----------+------+--------+----+--------+

4.3、特點(diǎn)

外連接中主表的數(shù)據(jù)一定會(huì)保存,連接之后不會(huì)出現(xiàn)記錄數(shù)少于主表(內(nèi)連接可能少數(shù)據(jù))

左連接和右連接可以相互轉(zhuǎn)換,但是數(shù)據(jù)對(duì)應(yīng)的位置(字段順序)會(huì)改變

4.4、應(yīng)用

獲取對(duì)應(yīng)主表以及其他數(shù)據(jù)(關(guān)聯(lián))

通常使用左連接

5、using關(guān)鍵字

在連接查詢中用來(lái)代替對(duì)應(yīng)on關(guān)鍵字進(jìn)行條件匹配

5.1、原理

  • 在連接查詢時(shí),使用on的地方用using代替
  • 使用using的前提是對(duì)應(yīng)的兩張表連接的字段名是同名的(類似自然連接)
  • 如果使用using關(guān)鍵字,那么對(duì)應(yīng)的同名字段,最后在結(jié)果中只會(huì)保留一個(gè)

5.2、基本語(yǔ)法

表1 [inner, left, right] join 表2 using (同名字段列表);
select * from my_student left join my_class using(class_id);
-- 等價(jià)于
select * from my_student left join my_class on my_student.class_id = my_class.class_id;

這個(gè)方法通常不使用

到此這篇關(guān)于MySQL數(shù)據(jù)庫(kù)連接查詢 join原理的文章就介紹到這了,更多相關(guān)MySQL連接查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySql存儲(chǔ)過(guò)程與函數(shù)詳解

    MySql存儲(chǔ)過(guò)程與函數(shù)詳解

    這篇文章主要為大家詳細(xì)介紹了MySql存儲(chǔ)過(guò)程與函數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2015-08-08
  • 快速增加MYSQL數(shù)據(jù)庫(kù)連接數(shù)負(fù)載能力的方法分享

    快速增加MYSQL數(shù)據(jù)庫(kù)連接數(shù)負(fù)載能力的方法分享

    mysql數(shù)據(jù)庫(kù)的負(fù)載能力除了和你機(jī)器硬件有關(guān),還有一個(gè)重要參數(shù)就是你系統(tǒng)的配置有關(guān),下面我來(lái)給大家介紹幾種提高M(jìn)YSQL數(shù)據(jù)庫(kù)連接數(shù)負(fù)載能力方法總結(jié),有需要的朋友可以參考一下
    2013-08-08
  • MySQL數(shù)據(jù)庫(kù)CPU飆升到100%的詳細(xì)解決方案

    MySQL數(shù)據(jù)庫(kù)CPU飆升到100%的詳細(xì)解決方案

    在監(jiān)控線上數(shù)據(jù)庫(kù)的運(yùn)行是否安全、正常的過(guò)程中,cpu使用率是一個(gè)重要的指標(biāo),一旦cpu使用率飆升至90%+甚至達(dá)到100%,必然會(huì)對(duì)數(shù)據(jù)庫(kù)的正常工作產(chǎn)生影響,下面這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫(kù)CPU飆升到100%的詳細(xì)解決方案,需要的朋友可以參考下
    2023-05-05
  • MySQL主從狀態(tài)檢查的實(shí)現(xiàn)

    MySQL主從狀態(tài)檢查的實(shí)現(xiàn)

    這篇文章主要介紹了MySQL主從狀態(tài)檢查的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • mysql合并多條記錄的單個(gè)字段去一條記錄編輯

    mysql合并多條記錄的單個(gè)字段去一條記錄編輯

    mysql怎么合并多條記錄的單個(gè)字段去一條記錄,今天在網(wǎng)上找了一下,方法如下
    2011-09-09
  • MySQL Truncate用法詳解

    MySQL Truncate用法詳解

    這篇文章主要介紹了MySQL Truncate用法的相關(guān)資料,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下
    2020-08-08
  • MySQL數(shù)據(jù)庫(kù)備份恢復(fù)實(shí)現(xiàn)代碼

    MySQL數(shù)據(jù)庫(kù)備份恢復(fù)實(shí)現(xiàn)代碼

    這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)備份恢復(fù)實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • MySql5.7.21安裝要點(diǎn)記錄筆記

    MySql5.7.21安裝要點(diǎn)記錄筆記

    這篇文章主要介紹了mysql5.7.21安裝要點(diǎn)記錄筆記,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • Mysql 本地計(jì)算機(jī)無(wú)法啟動(dòng) mysql 服務(wù) 錯(cuò)誤 1067:進(jìn)程意外終止。

    Mysql 本地計(jì)算機(jī)無(wú)法啟動(dòng) mysql 服務(wù) 錯(cuò)誤 1067:進(jìn)程意外終止。

    初學(xué)php接觸mysql,遇到一些問(wèn)題,卸載重裝后,無(wú)法啟動(dòng)mysql服務(wù),網(wǎng)絡(luò)上有很多種說(shuō)法,我這里將我解決這個(gè)問(wèn)題的辦法提出
    2009-12-12
  • mysql 基本操作

    mysql 基本操作

    早打算寫(xiě)些關(guān)于數(shù)據(jù)庫(kù)操作方面的知識(shí)了,現(xiàn)在終于完成了第一篇,以下記錄了關(guān)于mysql操作方面的基礎(chǔ)知識(shí)
    2012-08-08

最新評(píng)論