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

MySQL中表的幾種連接方式

 更新時(shí)間:2020年11月18日 09:07:19   作者:超人不會(huì)飛  
這篇文章主要給大家介紹了關(guān)于MySQL中表的幾種連接方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

MySQL表中的連接方式其實(shí)非常簡單,這里就簡單的羅列出他們的特點(diǎn)。

表的連接(JOIN)可以分為內(nèi)連接(JOIN/INNER JOIN)和外連接(LEFT JOIN/RIGHT JOIN)。

首先我們看一下我們本次演示的兩個(gè)表:

mysql> SELECT * FROM student;
+------+----------+------+------+
| s_id | s_name  | age | c_id |
+------+----------+------+------+
|  1 | xiaoming |  13 |  1 |
|  2 | xiaohong |  41 |  4 |
|  3 | xiaoxia |  22 |  3 |
|  4 | xiaogang |  32 |  1 |
|  5 | xiaoli  |  41 |  2 |
|  6 | wangwu  |  13 |  2 |
|  7 | lisi   |  22 |  3 |
|  8 | zhangsan |  11 |  9 |
+------+----------+------+------+
8 rows in set (0.00 sec)

mysql> SELECT * FROM class;
+------+---------+-------+
| c_id | c_name | count |
+------+---------+-------+
|  1 | MATH  |  65 |
|  2 | CHINESE |  70 |
|  3 | ENGLISH |  50 |
|  4 | HISTORY |  30 |
|  5 | BIOLOGY |  40 |
+------+---------+-------+
5 rows in set (0.00 sec)

首先,表要能連接的前提就是兩個(gè)表中有相同的可以比較的列。

1.內(nèi)連接

mysql> SELECT * FROM student INNER JOIN class ON student.c_id = class.c_id;
+------+----------+------+------+------+---------+-------+
| s_id | s_name  | age | c_id | c_id | c_name | count |
+------+----------+------+------+------+---------+-------+
|  1 | xiaoming |  13 |  1 |  1 | MATH  |  65 |
|  2 | xiaohong |  41 |  4 |  4 | HISTORY |  30 |
|  3 | xiaoxia |  22 |  3 |  3 | ENGLISH |  50 |
|  4 | xiaogang |  32 |  1 |  1 | MATH  |  65 |
|  5 | xiaoli  |  41 |  2 |  2 | CHINESE |  70 |
|  6 | wangwu  |  13 |  2 |  2 | CHINESE |  70 |
|  7 | lisi   |  22 |  3 |  3 | ENGLISH |  50 |
+------+----------+------+------+------+---------+-------+
7 rows in set (0.00 sec)

簡單的講,內(nèi)連接就是把兩個(gè)表中符合條件的行的所有數(shù)據(jù)一起展示出來,即如果不符合條件,即在表A中找得到但是在B中沒有(或者相反)的數(shù)據(jù)不予以顯示。

2.外連接

mysql> SELECT * FROM student LEFT JOIN class ON student.c_id = class.c_id;
+------+----------+------+------+------+---------+-------+
| s_id | s_name  | age | c_id | c_id | c_name | count |
+------+----------+------+------+------+---------+-------+
|  1 | xiaoming |  13 |  1 |  1 | MATH  |  65 |
|  2 | xiaohong |  41 |  4 |  4 | HISTORY |  30 |
|  3 | xiaoxia |  22 |  3 |  3 | ENGLISH |  50 |
|  4 | xiaogang |  32 |  1 |  1 | MATH  |  65 |
|  5 | xiaoli  |  41 |  2 |  2 | CHINESE |  70 |
|  6 | wangwu  |  13 |  2 |  2 | CHINESE |  70 |
|  7 | lisi   |  22 |  3 |  3 | ENGLISH |  50 |
|  8 | zhangsan |  11 |  9 | NULL | NULL  | NULL |
+------+----------+------+------+------+---------+-------+
8 rows in set (0.00 sec)


mysql> SELECT * FROM student RIGHT JOIN class ON student.c_id = class.c_id;
+------+----------+------+------+------+---------+-------+
| s_id | s_name  | age | c_id | c_id | c_name | count |
+------+----------+------+------+------+---------+-------+
|  1 | xiaoming |  13 |  1 |  1 | MATH  |  65 |
|  4 | xiaogang |  32 |  1 |  1 | MATH  |  65 |
|  5 | xiaoli  |  41 |  2 |  2 | CHINESE |  70 |
|  6 | wangwu  |  13 |  2 |  2 | CHINESE |  70 |
|  3 | xiaoxia |  22 |  3 |  3 | ENGLISH |  50 |
|  7 | lisi   |  22 |  3 |  3 | ENGLISH |  50 |
|  2 | xiaohong |  41 |  4 |  4 | HISTORY |  30 |
| NULL | NULL   | NULL | NULL |  5 | BIOLOGY |  40 |
+------+----------+------+------+------+---------+-------+
8 rows in set (0.00 sec)

上面分別展示了外連接的兩種情況:左連接和右連接。這兩種幾乎是一樣的,唯一的區(qū)別就是左連接的主表是左邊的表,右連接的主表是右邊的表。而外連接與內(nèi)連接不同的地方就是它會(huì)將主表的所有行都予以顯示,而在主表中有,其他表中沒有的數(shù)據(jù)用NULL代替。

總結(jié)

到此這篇關(guān)于MySQL中表的幾種連接方式的文章就介紹到這了,更多相關(guān)MySQL表的連接方式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Redis什么是熱Key問題以及如何解決熱Key問題

    Redis什么是熱Key問題以及如何解決熱Key問題

    這篇文章主要介紹了Redis什么是熱Key問題以及如何解決熱Key問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • MySQL如何改變表的存儲(chǔ)引擎方式

    MySQL如何改變表的存儲(chǔ)引擎方式

    這篇文章主要介紹了MySQL如何改變表的存儲(chǔ)引擎方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • mysql 循環(huán)insert方式

    mysql 循環(huán)insert方式

    這篇文章主要介紹了mysql 循環(huán)insert方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • mysql模糊匹配多個(gè)值的兩種方法實(shí)例

    mysql模糊匹配多個(gè)值的兩種方法實(shí)例

    我們平時(shí)使用msyql需要模糊的匹配字段的時(shí)候,我們第一反應(yīng)就是使用like查詢語句來模糊匹配,下面這篇文章主要給大家介紹了關(guān)于mysql模糊匹配多個(gè)值的兩種方法,需要的朋友可以參考下
    2022-12-12
  • MySQL解析JSON格式字段并取出部分值方式

    MySQL解析JSON格式字段并取出部分值方式

    這篇文章主要介紹了MySQL解析JSON格式字段并取出部分值方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • 一個(gè)案例徹底弄懂如何正確使用mysql inndb聯(lián)合索引

    一個(gè)案例徹底弄懂如何正確使用mysql inndb聯(lián)合索引

    今天小編就為大家分享一篇關(guān)于一個(gè)案例徹底弄懂如何正確使用mysql inndb聯(lián)合索引,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • MySQL子查詢中order by不生效問題的解決方法

    MySQL子查詢中order by不生效問題的解決方法

    ORDER BY 語句用于根據(jù)指定的列對(duì)結(jié)果集進(jìn)行排序,在日常工作中經(jīng)常會(huì)用到,這篇文章主要給大家介紹了關(guān)于MySQL子查詢中order by不生效問題的解決方法,需要的朋友可以參考下
    2021-07-07
  • 將MySQL數(shù)據(jù)導(dǎo)出為sql文件的最佳實(shí)踐

    將MySQL數(shù)據(jù)導(dǎo)出為sql文件的最佳實(shí)踐

    這篇文章主要給大家介紹了如何將MySQL數(shù)據(jù)導(dǎo)出為sql文件,避免數(shù)據(jù)丟失的最佳實(shí)踐,文中有詳細(xì)的導(dǎo)出流程步驟,跟著文中的步驟就可以導(dǎo)出文件,需要的朋友可以借鑒參考
    2023-07-07
  • MySQL的時(shí)間差函數(shù)TIMESTAMPDIFF、DATEDIFF的用法

    MySQL的時(shí)間差函數(shù)TIMESTAMPDIFF、DATEDIFF的用法

    這篇文章主要介紹了MySQL的時(shí)間差函數(shù)TIMESTAMPDIFF、DATEDIFF的用法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • 一次mysql的.ibd文件過大處理過程記錄

    一次mysql的.ibd文件過大處理過程記錄

    mysql數(shù)據(jù)庫的每個(gè)表都有ibd和frm兩種格式的文件,ibd文件是表的數(shù)據(jù)文件,存放表的數(shù)據(jù),修改文件后綴,無法在MySQL數(shù)據(jù)庫中查詢表數(shù)據(jù),這篇文章主要給大家介紹了關(guān)于一次mysql的.ibd文件過大處理過程的相關(guān)資料,需要的朋友可以參考下
    2022-06-06

最新評(píng)論