Mysql基礎8-多表查詢

来源:https://www.cnblogs.com/Se7eN-HOU/archive/2023/07/21/17568632.html
-Advertisement-
Play Games

一、多表關係 一對多或者多對一 案例:部門與員工的關係 關係:一個部門對應多個員工,一個員工對應一個部門(不考慮跨部門的特殊情況) 實現:在多的一方建立外鍵,指向一的一方的主鍵,這裡員工表是多的的一方,部門表是一的一方 多對多 案例:學生與課程的關係 關係:一個學生可以選修多門課程,一門課程也可以供 ...


一、多表關係

  • 一對多或者多對一

    • 案例:部門與員工的關係
    • 關係:一個部門對應多個員工,一個員工對應一個部門(不考慮跨部門的特殊情況)
    • 實現:在多的一方建立外鍵,指向一的一方的主鍵,這裡員工表是多的的一方,部門表是一的一方

      

 

  • 多對多

    • 案例:學生與課程的關係
    • 關係:一個學生可以選修多門課程,一門課程也可以供多個學生選擇
    • 實現:建立第三張中間表,中間表至少包含兩個外鍵,分別關聯兩方主鍵  

      

  • 一對一

    • 案例:用戶與用戶詳情的關係
    • 關係:一對一關係,多用於單表拆分,將一張表的基礎欄位放在一張表,其他詳情欄位放在另外一張表中,藝體生操作效率
    • 實現:在任意一方加入外鍵,關聯另外一方的主鍵,並且設置為唯一的(unique)
    • 說明:這個是外鍵user_id需要加一個約束保證其唯一,從而保證一個詳情只能對應一個用戶。

      

二、多表查詢

  2.1、概述:

    多表查詢指從多張數據表中查詢數據

  2.2、分類:

    • 連接查詢
      • 內連接:相當於查詢A、B交集部分數據
      • 外連接
        • 左外連接:查詢左表所有數據,以及兩張表交集部分數據
        • 右外連接:查詢右表所有數據,已經兩張表交集部分數據:
      • 自連接:當前表與自身的連接查詢,連接必須使用表別名
    • 子查詢
    • 聯合查詢

三、示例數據表結構及數據

  3.1、emp:員工表結構及數據

mysql> select * from emp;
+----+--------+------+--------------+--------+------------+-----------+---------+
| id | name   | age  | job          | salary | entrydate  | managerid | dept_id |
+----+--------+------+--------------+--------+------------+-----------+---------+
|  1 | 張三   |   43 | 董事長       |  48000 | 2017-07-20 |      NULL |       5 |
|  2 | 李四   |   38 | 項目經理     |  23900 | 2016-08-20 |         1 |       1 |
|  3 | 問問   |   22 | 開發         |  18000 | 2022-07-20 |         2 |       1 |
|  4 | 芳芳   |   22 | 開發         |  21000 | 2019-08-18 |         2 |       1 |
|  5 | 珊珊   |   22 | 開發         |  15000 | 2021-04-10 |         3 |       1 |
|  6 | 娜娜   |   25 | 財務         |  24000 | 2023-07-16 |         1 |       3 |
|  7 | 咔咔   |   25 | 出納         |   8000 | 2021-07-10 |         6 |       3 |
|  8 | 靜靜   |   27 | 人事         |   5000 | 2021-07-11 |         1 |    NULL |
+----+--------+------+--------------+--------+------------+-----------+---------+
8 rows in set (0.00 sec)

 

  3.2、dept:部門表結構及數據

mysql> select * from dept;
+----+-----------+
| id | name      |
+----+-----------+
|  1 | 研發部    |
|  2 | 市場部    |
|  3 | 財務部    |
|  4 | 銷售部    |
|  5 | 總經辦    |
|  6 | 人事部    |
+----+-----------+
6 rows in set (0.00 sec)

   

  3.3、score1:成績表1結構及數據

mysql> select * from score1;
+----+--------+-------+
| id | name   | score |
+----+--------+-------+
|  1 | 張三   |    94 |
|  2 | 李四   |    93 |
|  3 | 王五   |    87 |
|  4 | 趙六   |    71 |
+----+--------+-------+
4 rows in set (0.00 sec)

  

  3.4、score2:成績表2結構及數據

mysql> select * from score2;
+----+--------+-------+
| id | name   | score |
+----+--------+-------+
|  1 | 張三   |    94 |
|  2 | 李四   |    97 |
|  3 | 王五   |    91 |
|  4 | 趙六   |    82 |
+----+--------+-------+
4 rows in set (0.00 sec)

 

四、內連接

  4.1、概述:

    內連接查詢的是兩張表的交集的部分

  4.2、內連接查詢語法

    4.2.1 隱式內連接

select 欄位列表 from 表1,表2 where 條件...;

    4.2.2 顯示內連接 inner可以省略不寫

select 欄位列表 from 表1 [inner] join 表2 on 連接條件...;   

  4.3、案例

    案例1:查詢每個員工的姓名,及關聯的部門的名稱(隱式內連接實現)

mysql> select emp.name,dept.name as dept_name from emp,dept where emp.dept_id = dept.id;
+--------+-----------+
| name   | dept_name |
+--------+-----------+
| 張三   | 總經辦    |
| 李四   | 研發部    |
| 問問   | 研發部    |
| 芳芳   | 研發部    |
| 珊珊   | 研發部    |
| 娜娜   | 財務部    |
| 咔咔   | 財務部    |
+--------+-----------+
7 rows in set (0.00 sec)

 

    案例2:查詢每個員工的姓名,及關聯的部門的名稱(顯示內連接實現)

mysql> select emp.name,dept.name as dept_name from emp inner join dept on emp.dept_id = dept.id;
+--------+-----------+
| name   | dept_name |
+--------+-----------+
| 張三   | 總經辦    |
| 李四   | 研發部    |
| 問問   | 研發部    |
| 芳芳   | 研發部    |
| 珊珊   | 研發部    |
| 娜娜   | 財務部    |
| 咔咔   | 財務部    |
+--------+-----------+
7 rows in set (0.00 sec)

 

五、外連接

  5.1、左外連接

    簡介:相當於查詢表1(左表)的所有數據,包含表1和表2交集部分的數據

select 欄位列表 from 表1 left [outer] join 表2 on 條件...;

 

  5.2、右外連接

    簡介:相當於查表2(右表)的所有數據,包含表1和表2交集部分的數據

select 欄位列表 from 表1 right [outer] join 表2 on 條件...; 

  

  5.3、案例

    案例1:查詢emp表的所有數據,和對應的部門信息(左外連接)

mysql> select emp.*, dept.name as dept_name from emp left join dept on emp.dept_id = dept.id;
+----+--------+------+--------------+--------+------------+-----------+---------+-----------+
| id | name   | age  | job          | salary | entrydate  | managerid | dept_id | dept_name |
+----+--------+------+--------------+--------+------------+-----------+---------+-----------+
|  1 | 張三   |   43 | 董事長       |  48000 | 2017-07-20 |      NULL |       5 | 總經辦    |
|  2 | 李四   |   38 | 項目經理     |  23900 | 2016-08-20 |         1 |       1 | 研發部    |
|  3 | 問問   |   22 | 開發         |  18000 | 2022-07-20 |         2 |       1 | 研發部    |
|  4 | 芳芳   |   32 | 開發         |  21000 | 2019-08-18 |         2 |       1 | 研發部    |
|  5 | 珊珊   |   27 | 開發         |  15000 | 2021-04-10 |         3 |       1 | 研發部    |
|  6 | 娜娜   |   25 | 財務         |  24000 | 2023-07-16 |         1 |       3 | 財務部    |
|  7 | 咔咔   |   29 | 出納         |   8000 | 2021-07-10 |         6 |       3 | 財務部    |
|  8 | 靜靜   |   27 | 人事         |   5000 | 2021-07-11 |         1 |    NULL | NULL      |
+----+--------+------+--------------+--------+------------+-----------+---------+-----------+
8 rows in set (0.00 sec)

    說明1:查詢emp表的所有數據,即emp.*

    說明2:as dept_name 是給dept.name 起的別名,防止查詢結果中出現兩個name欄位,會有歧義

    說明3:from 後面的是左表,所以該語句中emp是左表

    說明4:join 後面的是右表,所以該語句中的dept是右表

    說明5:連接關係是emp.dept_id = dept.id

    說明6:outer關鍵字是可以省略的,不影響結果

 

    案例2:查詢dept表的所有數據,和對應的員工信息(右外連接)
mysql> select dept.*, emp.* from emp right join dept on emp.dept_id = dept.id;
+----+-----------+------+--------+------+--------------+--------+------------+-----------+---------+
| id | name      | id   | name   | age  | job          | salary | entrydate  | managerid | dept_id |
+----+-----------+------+--------+------+--------------+--------+------------+-----------+---------+
|  1 | 研發部    |    2 | 李四   |   38 | 項目經理     |  23900 | 2016-08-20 |         1 |       1 |
|  1 | 研發部    |    3 | 問問   |   22 | 開發         |  18000 | 2022-07-20 |         2 |       1 |
|  1 | 研發部    |    4 | 芳芳   |   22 | 開發         |  21000 | 2019-08-18 |         2 |       1 |
|  1 | 研發部    |    5 | 珊珊   |   22 | 開發         |  15000 | 2021-04-10 |         3 |       1 |
|  2 | 市場部    | NULL | NULL   | NULL | NULL         |   NULL | NULL       |      NULL |    NULL |
|  3 | 財務部    |    6 | 娜娜   |   25 | 財務         |  24000 | 2023-07-16 |         1 |       3 |
|  3 | 財務部    |    7 | 咔咔   |   25 | 出納         |   8000 | 2021-07-10 |         6 |       3 |
|  4 | 銷售部    | NULL | NULL   | NULL | NULL         |   NULL | NULL       |      NULL |    NULL |
|  5 | 總經辦    |    1 | 張三   |   43 | 董事長       |  48000 | 2017-07-20 |      NULL |       5 |
|  6 | 人事部    | NULL | NULL   | NULL | NULL         |   NULL | NULL       |      NULL |    NULL |
+----+-----------+------+--------+------+--------------+--------+------------+-----------+---------+
10 rows in set (0.00 sec)

    說明1:查詢dept表的所有數據,又因為要求使用右連接,所以需要將右表作為主表,即dept要放在join關鍵字的後面

    說明2:連接關係依然是emp.dept_id = dept.id

mysql> select dept.*, emp.* from dept left join emp on emp.dept_id = dept.id;
+----+-----------+------+--------+------+--------------+--------+------------+-----------+---------+
| id | name      | id   | name   | age  | job          | salary | entrydate  | managerid | dept_id |
+----+-----------+------+--------+------+--------------+--------+------------+-----------+---------+
|  1 | 研發部    |    2 | 李四   |   38 | 項目經理     |  23900 | 2016-08-20 |         1 |       1 |
|  1 | 研發部    |    3 | 問問   |   22 | 開發         |  18000 | 2022-07-20 |         2 |       1 |
|  1 | 研發部    |    4 | 芳芳   |   22 | 開發         |  21000 | 2019-08-18 |         2 |       1 |
|  1 | 研發部    |    5 | 珊珊   |   22 | 開發         |  15000 | 2021-04-10 |         3 |       1 |
|  2 | 市場部    | NULL | NULL   | 
              
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • # Avalonia 使用EFCore調用SQLite實現Singleton全局註冊 ![image-20230720204001797](https://www.raokun.top/upload/2023/07/image-20230720204001797.png) 本篇博客是我的開源項目[T ...
  • asp.net項目開發過程中用到了多個程式集(dll), 如何根據類型全名(fullname)獲取類型信息? 如果項目(csproj)中設置了引用對應的dll 或nupkg包,但是代碼中沒有任務地方引用改該程式集的類,則實際上運行時,該程式集不會被載入到進程中. 假設有一個 ThirdModels. ...
  • # Unity UGUI的CanvasScaler(畫布縮放器)組件的介紹及使用 ## 1. 什麼是CanvasScaler組件? CanvasScaler是Unity中UGUI系統中的一個組件,用於控制畫布的縮放和適配。通過CanvasScaler組件,可以實現UI界面在不同解析度下的自適應顯示。 ...
  • ### 描述 asp.net Core Identity提供給我們一組工具包和API,能幫助我們應用程式創建授權和認證功能。也可以用它創建賬戶並使用用戶名和密碼進行登錄,同時也提供了角色和角色管理功能。 #### 1.創建項目 - 配置項 - nuget包 - Microsoft.AspNetCor ...
  • # shell腳本-DOS攻擊防範(自動屏蔽攻擊IP) ## 原理: #### **找出異常ip** > 通過獲取伺服器access.log日誌信息,獲取時間在每分鐘之內每個ip訪問的次數來判斷此ip是否是DOS攻擊。 > > grep $(date +%d/%b/%Y:%H:%M) 過濾得到沒分鐘 ...
  • **註:** Silverlight工作流控制項,如果在網頁中打不開,則要判斷是否缺少`Silverlight工作流控制項`的插件程式,如果不是則可以進行一下步驟檢查,如果是以下原因則是:由於IIS版本問題,安裝後可能出現不支持wcf服務的請求處理,需要手動添加處理程式;資料庫客戶端如果是64位,需要修 ...
  • 今天給大家分享一下STM32 流水燈簡單的模擬吧,我感覺這個提供有用的,但是自己也是第一次使用,主要是感覺曲線很高級。在PWM中查看脈寬很有用。 code: led.c #include "led.h"#include "delay.h"/*GPIO的控制寄存器的配置1、配置輸出引腳2、打開對應的輸 ...
  • # clion申請教育認證 ## 1、註冊jetbrains賬號 [jetbrains註冊賬號網站鏈接](https://account.jetbrains.com/login) ![picture 1](https://img2023.cnblogs.com/blog/2915785/202307 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...