MySql 多表查詢

来源:http://www.cnblogs.com/shilei182/archive/2017/08/02/7274981.html
-Advertisement-
Play Games

多表查詢必然要用到多表關聯 多表關聯 分三類: A:內部連接 join 或inner join B:外部鏈接 外部連接又分為兩類 :左外連接 left join 和右外連接 right join C:交叉連接 cross join 以下 舉例說明 有兩張表 格 一張學生的 一張老師的 一張中間表的 ...


多表查詢必然要用到多表關聯

多表關聯 分三類:

A:內部連接  join  或inner join

B:外部鏈接  外部連接又分為兩類   :左外連接 left join 和右外連接 right join

C:交叉連接 cross  join 

以下 舉例說明  有兩張表

格 一張學生的   一張老師的  一張中間表的

 

 

 

一、內部鏈接 應用場景 

 

 

 這種條件下是得到 A B  共同的數據 同時滿足AB 的條件   稱之為內部連接

代碼 是 :

SELECT *FROM stu_tea st JOIN student s ON st.學生=s.name

結果是:

 

   

 

從表中清楚 看出,studnet表中的信息會按照規定的規則(中間表中的“學生欄位”=student表中的name 欄位)拼接在關聯的後面,並且仔細看 可以發現 少了學生陳建和李濤的信息,因為陳建和李濤這兩個學生在兩個表中並不同時存在

 

如果要對結果表中的學生和name重覆的 只顯示一行,可以對代碼以下處理

SELECT st.`學生`,st.`老師`,s.`birth`FROM stu_tea st JOIN student s ON st.學生=s.name

結果如下:

還可以對s.birth中文化處理,在後面加上別名顯示:

SELECT st.`學生`,st.`老師`,s.`birth` '生日' FROM stu_tea st JOIN student s ON st.學生=s.name

結果如下:

註意:以上代碼中的中文欄位,加不加引號都可以,系統一般預設加單引號;

 

二、外部鏈接 應用場景 

左外連接

這種場景是得到A的所有數據和B滿足一定條件的部分數據

 

代碼是:SELECT *FROM stu_tea st LEFT JOIN student s ON st.`學生`=s.`name`

結果為:

    

從表中可以看出,左外連接完全以左邊的中間表為模板,學生表接在中間標的後面,,沒有數據用null補齊,學生表有的而中間表沒有的數據則不會顯示

 對以上結果,還可以用where 從句 進一步篩選

 比如要去掉沒有學生信息的數據:SELECT *FROM stu_tea st LEFT JOIN student s ON st.`學生`=s.`name` WHERE s.`name`IS NOT NULL 

結果是:

我們還查詢一下,去掉了哪些學生信息:SELECT *FROM stu_tea st LEFT JOIN student s ON st.`學生`=s.`name` WHERE s.`name`IS NULL 

結果是:

註意:MySQL 只能用 is 不能用”=“

右外連接

這種場景是得到B的所有數據和A滿足一定條件的部分數據

 右外部連接與左外部連接 完全相反,不具體介紹

 

 

三、交叉連接

 實際應用中還有這樣一種情形,想得到A,B記錄的排列組合,即笛卡兒積,這個就不好用集合和元素來表示了。需要用到cross join

代碼是:SELECT *FROM stu_tea st CROSS JOIN student

結果是:

 

 可以發現student表中一共有5行數據 ,stu_tea表中 有12行數據,60=12*5;

此代碼也可以寫成SELECT *FROM stu_tea st  JOIN student

 

註意事項:

1.連接表格使用的是逗號,會被解釋為交叉連接;

即SELECT *FROM stu_tea st,student   SELECT *FROM stu_tea st  JOIN student      SELECT *FROM stu_tea st CROSS JOIN student  是等價的

2.一般內連接都需要加上on限定條件,如果不加會被解釋為交叉連接

3.一般交叉連接(, cross join join 都可以)後面加上where條件,也可以寫成on


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

-Advertisement-
Play Games
更多相關文章
  • 線性佈局LinearLayout 一、簡介 LinearLayout是一種線型的佈局方式。LinearLayout佈局容器內的組件一個挨著一個地排列起來:不僅可以控制個組件橫向排列,也可控制各組件縱向排列。通過orientation屬性設置線性排列的方向是垂直(vertical)還是縱向(horiz ...
  • android視圖概述 一、簡介 數據和控制項分開的作用: 便於引用 便於修改:修改的時候直接改一次數據就可以了 ...
  • 要求:載入全部的訂單,每個訂單裡面有一個或者多個產品,在列表中要展現出來, 1. xaml界面 步驟:1.這裡使用的是x:bind綁定所以要引入實體類命名空間(OrderList集合中類的命名空間): xmlns:order="using:GemallApp.Core.Models" 2. <Lis ...
  • 要求:評論寶貝的時候一個訂單裡面包含多個產品,獲取對產品的評論內容哦 1. xaml界面 要求:獲取ListView中x:Name為tbContent的值(評論內容) 第一步:綁定TextBox的值使用Mode=TwoWay <TextBox x:Name="tbContent" Text="{Bi ...
  • 1.要求: 發送驗證碼按鈕,點擊後,會倒計時60s,之後才能再次點擊。不同界面的多個驗證碼按鈕共用這個倒計時時間。 2.操作步驟 1) 從登錄界面-->忘記密碼輸入手機號-->下一步-->倒計時60s 2) 返回到註冊頁面-->輸入手機號碼-->下一步-->獲取計時器倒計時到48s,然後從48s繼續 ...
  • 1.從相冊裡面選取圖片 2.從相機裡面選取圖片 3.裁剪圖片調用的公共方法CutPicture 4.使用Windows.Web.Http命名空間下的HttpClient使用post方法,上傳圖片伺服器 參考:https://social.msdn.microsoft.com/Forums/zh-CN ...
  • 一:Redis是什麼? Redis全稱:REmote DIctionary Server(Redis) 。Redis是一個由Salvatore Sanfilippo寫的key-value存儲系統,ANSI C語言編寫; 特點:開源免費、單線程、大併發、遵守BSD協議、支持網路、可基於記憶體亦可持久化、 ...
  • 摘自:《高性能Mysql》 1. 哈希索引基於哈希表實現,只有精確的匹配索引所有列的查詢才有效,對於每一行數據,存儲引擎會對所有的索引列計算一個哈希碼,並將哈希碼存儲在索引中,同時在哈希表中保存只想每個數據行指針 mysql中,只有memory引擎顯示支持哈希索引,並且支持非唯一哈希索引。也是mem ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...