SQL中的LEFT RIGHT INNER JOIN的區別及學習

来源:https://www.cnblogs.com/itdouzy/archive/2018/04/25/8931188.html
-Advertisement-
Play Games

SQL中的LEFT RIGHT INNER JOIN的區別及學習,僅供參考,如有錯誤,歡迎糾正。 ...


       多表連接,在工作中是經常遇見的,現在來講講LEFT、RIGHT和INNER JOIN的用法,用法會了區別就出來了,寫的不專業,只是為了便於理解和學習。

       首先講INNER JOIN的使用,INNER JOIN是根據ON的條件過濾出兩表條件相同的數據,如圖的Student表和Course表。

      1、查詢“張大大”選修了那些課程(為方便用*查出所有的欄位)

 

 

SELECT *

FROM Student s

INNER JOIN Course c

ON s.課程號=c.課程號

WHERE c.姓名=“張大大”;

分析:ON後面的條件是 s.課程號=c.課程號,根據條件,兩個表相同的是“1101”,所以結果就是

 

   LEFT JOIN左連接,顧名思義,向左連接,左表是主表,查詢主表的所有數據,過濾ON條件符合的右表的數據,還是以Student和Course為例。

        2、使用LEFT JOIN查詢所有學生的選課情況。

       SELECT * 

       FROM  Student s 

       LEFT JOIN Course c

  ON s.課程號=c.課程號;

分析:首先要明白那個是主表也就是左表,這個靠平時接觸的多了就會了,Student表是主表,Course是右表,查詢Student表所有的信息,過濾ON條件相同的Course數據,所以結果是:

 

  RIGHT JOIN 和LEFT JOIN是相反的,右邊是主表,LEFT 和 RGITH JOIN 理解一個就都明白了,主要還是找主表。

  3、使用RIGHT JOIN查詢課程的選課情況。

  SELECT * 

  FROM  Student s

  RIGHT JOIN Course c

  ON s.課程號=c.課程號;

分析:主表是Course所以放在右邊,左邊Student則是要過濾的表。所以結果是:

 結語:我平常用的INNER JOIN和LEFT JION比較多,RIGHT JOIN和LEFT JOIN 一樣,只是換換位置的問題。

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Oozie Spark Action 配置 Spark Action 用來運行spark 任務,流程任務必須等當前節點的spark任務執行完成之後才能執行後續節點任務。運行Spark Job,必須在 spark action裡面配置 job-tracer,name-node,master,和一些必要 ...
  • Oozie Email Action 配置 Shell Action 可以用來為oozie中的流程任務發送郵件,Email Action 必須配置 to收件人,cc收件人(可選),郵件主題,郵件內容,多個收件人可以使用,分割收件人地址。Email Action是同步執行的,流程任務必須等當前節點的郵 ...
  • row_number的用途非常廣泛,排序最好用它,它會為查詢出來的每一行記錄生成一個序號,依次排序且不會重覆,註意使用row_number函數時必須要用over子句選擇對某一列進行排序才能生成序號。 rank函數用於返回結果集的分區內每行的排名,行的排名是相關行之前的排名數加一。簡單來說rank函數 ...
  • 涉及到sock連接的問題。 為了測試MySQL的某些個特性,在一個機器上安裝了多個MySQL的實例,如下截圖,有兩個實例,一個埠是8000,一個埠是8001。在使用mysql -uroot -p -P8001連接至埠號為8001的MySQL實例的時候,show variables like ' ...
  • 今天安裝完Mysql後,開啟發生了錯誤: 1、打開相應文件夾,查看錯誤信息: 2、打開錯誤信息文件,查看錯誤原因是:Plugin 'FEDERATED' is disabled. /usr/sbin/mysqld: Table 'mysql.plugin' doesn't exist 3、‘mysq ...
  • 本文目錄: 1.1 視窗和開窗函數簡介 1.2 OVER()語法和執行位置 1.3 row_number()對分區排名 1.4 rank()和dense_rank() 1.5 percent_rank()和cume_dist() 1.6 ntile()數據分組 1.7 取相鄰行數據:lag()函數和 ...
  • 想用linux虛擬機裝一個oracle,中間遇到的坑太多了,最後總算是安裝好了,一定要寫個全面的教程出來。 話不多說 通用編輯命令: vi test.txt #進入編輯模式 編輯完成後按ESC退出編輯模式 :wq 回車 保存編輯的文件 1.設置linux開機自動打開網路連接,不打開網路連接Secur ...
  • Mysql遠程連接 Host * is not allowed to connect to this MySQL server 解決辦法:在本機登入mysql後,選擇用戶,修改你遠程鏈接的用戶的主機,從 localhost 改為 % ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...