MySQL之表、列別名及各種JOIN連接詳解

来源:https://www.cnblogs.com/share-record/archive/2020/02/04/12262149.html
-Advertisement-
Play Games

MySQL在SQL中,合理的別名可以讓SQL更容易以及可讀性更高。別名使用as來表示,可以分為表別名和列別名,別名應該是先定義後使用才對,所以首先要瞭解sql的執行順序(1) from(2) on(3) join(4) where(5) group by(開始可以使用select的別名,後面的也行) ...


MySQL
在SQL中,合理的別名可以讓SQL更容易以及可讀性更高。別名使用as來表示,可以分為表別名和列別名,別名應該是先定義後使用才對,所以首先要瞭解sql的執行順序
(1) from
(2) on
(3) join
(4) where
(5) group by(開始可以使用select的別名,後面的也行)
(6) avg,sum…
(7) having
(8) select
(9) distinct
(10) order by
註意:from是最先執行的,select是在having之後運行的
這裡有兩張表

 

 

 1.1 列別名
SQL語句select id,name as colname from students;,結果為

 

 

 

在這裡可以看到我們給 name 添加了一個別名,輸出後原表的 name 欄位變為現在的別名欄位 colname;
1.2 表別名
SQL語句select stu.name,sc.score from students as stu,score as sc where stu.id=sc.id;,結果為

 

 

 我們給表students起個別名stu,給score起個別名sc。

 

JOIN連接
2.1 inner join
以上面兩表為例,下麵連接上面的兩張表,匹配id相同的信息
SQL語句為select a.id,a.name,a.subject,b.score from students a inner join score b on a.id=b.id;(on/where),結果是

 

 INNER JOIN 的表關聯模型如下:

 

 

綠色部分即為兩張表關聯的部分。
2.2 left join
LEFT JOIN 與 INNER JOIN 有所不同,LEFT JOIN 會讀取左側數據表的全部數據,即使右側表中無對應數據。我們將students表作為左側表,score為右側表
SQL語句select a.id,a.name,a.subject,b.score from students a left join score b on a.id=b.id;結果為

 

因為兩張表的id均為3,所以結果看起來和inner join效果一樣,其實不然,這裡重點將用法!!!
LEFT JOIN 的表關聯模型如下:

 

 

 上圖中綠色的部分,為兩表的左關聯結果。


原文鏈接:https://blog.csdn.net/sun_xiao_kai/article/details/88075501

如有侵權,請立即聯繫我


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

-Advertisement-
Play Games
更多相關文章
  • 鋼琴案例 (按下1-9數字鍵,能觸發對應的mouseenter事件) 1. 結合之前的學習,主要內容,就是on註冊keyup事件,函數里傳入e, 用e.keyCode,來獲取1-9的數字的範圍。 如果所按的按鍵在49-57的範圍里,就去觸發mouseenter(or mouseleave)事件。 怎 ...
  • 原文地址: "使用typescript改造koa開發框架" 強類型的 TypeScript 開發體驗和維護項目上相比 JavaScript 有著明顯的優勢,那麼對常用的腳手架進行改造也就勢在必行了。 接下來開始對基於 koa 框架的 node 後端腳手架進行改造: 1. 項目開發環境 和 types ...
  • str.toString() 可以把字元串、數值、布爾值、對象轉為字元串 String(str) 任何數值強制轉換為字元串類型 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> ...
  • 事件對象 jQuery事件對象其實就是js事件對象的一個封裝,處理了相容問題 e.data 存儲綁定事件時傳遞的附件數據 傳入e, 再console.log(e)可以查看 //100,註冊的時候的時候,把100傳到事件裡面去。 var money = 100; //on(types, selecto ...
  • 事件解綁與事件觸發 $("p").off("click"); $("#btn").on("click", function () { //觸發p元素的點擊事件 //$("p").click(); $("p").trigger("click"); }); ...
  • Kafka系列1:Kafka概況 Kafka是當前分散式系統中最流行的消息中間件之一,憑藉著其高吞吐量的設計,在日誌收集系統和消息系統的應用場景中深得開發者喜愛。本篇就聊聊Kafka相關的一些知識點。主要包括以下內容: Kafka簡介 Kafka特點 Kafka基本概念 Kafka架構 Kafka的 ...
  • 學習要求: 知道一點兒函數式介面和Lambda表達式的基礎知識,有利於更好的學習。 1.先體驗一下Stream的好處 需求:給你一個ArrayList用來保存學生的成績,讓你列印出其中大於60的成績。 解決方案二: 使用Stream流操作,只需要一行代碼 2.什麼是Stream流? 在Jdk1.8中 ...
  • 一、 Calendar解析 package com.bjpowernode.java_learning; import java.util.Date; import java.text.ParseException; import java.text.SimpleDateFormat; import ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...