MySQL的select(極客時間學習筆記)

来源:https://www.cnblogs.com/wadmwz/archive/2019/06/25/11080703.html
-Advertisement-
Play Games

查詢語句 首先, 準備數據, 地址是: https://github.com/cystanford/sql_heros_data, 除了id以外, 24個欄位的含義如下: 查詢 查詢分為單列查詢, 多列查詢, 全部查詢等等: 學習階段可以使用SELECT , 但是在生產環境不要用, 因為效率會非常低 ...


查詢語句

首先, 準備數據, 地址是: https://github.com/cystanford/sql_heros_data, 除了id以外, 24個欄位的含義如下:

查詢

查詢分為單列查詢, 多列查詢, 全部查詢等等:

SELECT name FROM heros; // 單列查詢
SELECT name, hp_max, mp_max, attack_max, defense_max FROM heros; // 多列查詢
SELECT * FROM heros; // 全部查詢

學習階段可以使用SELECT *, 但是在生產環境不要用, 因為效率會非常低.

起別名

起別名是一種技巧, 可以對原有名稱進行簡化, 讓SQL語句看起來更加精簡, 這個在多表連接查詢的時候非常有用:

SELECT name AS n, hp_max AS hm, mp_max AS mm, attack_max AS am, defense_max AS dm FROM heros; // 起別名查詢

查詢常數

SELECT 查詢可以對常數進行查詢, 簡單說就是在SELECT查詢結果中增加一列固定的常數列. 一般用於整合不同的數據源, 用常數作為這個表的標記.

SELECT '王者榮耀' as platform, name FROM heros; // 查詢常數

虛構了一個platform欄位, 註意的是, 字元串常數要是用單引引起來, 否則會被當做列名來進行查詢, 會報錯, 如果是數字的話不需要添加單引號.

去除重覆行

去除重覆行是個非常少實用的操作, 關鍵字是DISTINCT:

SELECT DISTINCT attack_range FROM heros; 
SELECT DISTINCT attack_range, name FROM heros

需要註意的是:

  1. DISTINCT需要放在所有的列名之前, 也就是SELECT 之後.
  2. DISTINCT其實是對後面所有列名的組合進行去除, 並不是對某一列進行去重. 這也是為什麼DISTINCT要放在所有的列名之前的原因.

排序檢索數據

檢索數據的時候, 可以按照某種順序來進行結果的返回, 比如說查詢所有的英雄, 按照最大生命從高到低的順序進行排列, 這個時候排序就要使用到 ORDER BY 子句了, 註意點如下:

  1. 排序的列名: ORDER BY後面可以有一個或多個列名, 如果是多個列名進行排序, 會按照後面第一個列先進行排序, 當第一個列的值相同的時候, 再按照第二個列進行排序, 以此類推.
  2. 排序的順序: ORDER BY後面可以註明排序規則, ASC代表遞增排序, DESC代表遞減排序, 沒有註明規則, 預設是遞增排序. 還有對數值類型欄位的排序很容易理解, 那如果是文本數據呢? 需要參考資料庫的設置方式, 才可以進行判斷.
  3. 非選擇列排序: ORDER BY 可以使用非選擇列進行排序, 也就是說SELECT後面沒有這個列名, 同樣可以放到ORDER BY後面進行排序.
  4. ORDER BY的位置: ORDER BY通常位於SELECT語句的最後一條子句, 否則會報錯.
SELECT name, hp_max FROM heros ORDER BY hp_max DESC ; // 最大生命排序
SQL:SELECT name, hp_max FROM heros ORDER BY mp_max, hp_max DESC; // 最大法力升序, 法力相同, 生命值降序排序

約束返回結果的數量

約束返回結果的數量, 使用LIMIT關鍵字.

SELECT name, hp_max FROM heros ORDER BY hp_max DESC LIMIT 5; // 最大生命值從高到低排序並返回前五條數據

註意的是在不同的DBMS中, 使用的關鍵字可能不同. 在 MySQL、PostgreSQL、MariaDB 和 SQLite 中使用 LIMIT 關鍵字,而且需要放到 SELECT 語句的最後面。如果是 SQL Server 和 Access,需要使用 TOP 關鍵字

SELECT TOP 5 name, hp_max FROM heros ORDER BY hp_max DESC;

如果是 DB2,使用FETCH FIRST 5 ROWS ONLY這樣的關鍵字

SELECT name, hp_max FROM heros ORDER BY hp_max DESC FETCH FIRST 5 ROWS ONLY; 

如果是 Oracle,你需要基於 ROWNUM 來統計行數:

SQL:SELECT name, hp_max FROM heros WHERE ROWNUM <=5 ORDER BY hp_max DESC;

約束返回結果數量可以減少數據表的網路傳輸量, 可以提升查詢效率.

SELECT的執行順序

這裡要說的是兩個順序, 一個是關鍵字的順序, 一個是SELECT語句的執行順序:

  1. 關鍵字的順序:
SELECT ... FROM ... WHERE ... GROUP BY ... HAVING ... ORDER BY ...
  1. SELECT語句的執行順序
FROM > WHERE > GROUP BY > HAVING > SELECT 的欄位 > DISTINCT > ORDER BY > LIMIT

一條SQL語句, 關鍵字順序和執行順序如下:

SELECT DISTINCT player_id, player_name, count(*) as num # 順序 5
FROM player JOIN team ON player.team_id = team.team_id # 順序 1
WHERE height > 1.80 # 順序 2
GROUP BY player.team_id # 順序 3
HAVING num > 2 # 順序 4
ORDER BY num DESC # 順序 6
LIMIT 2 # 順序 7

在SELECT語句執行這些步驟的時候, 每個步驟都會生成一張虛擬表, 然後將這個虛擬表傳入下一個步驟作為輸入. 但是這些步驟是隱含在SQL的執行過程中, 對我們是不可見的.

SQL的執行原理

SELECT是先執行FROM這一步的, 這個階段, 如果是多張表聯查, 會經歷下麵的步驟:

  1. 首先通過笛卡爾積, 得到虛擬表vt(virtual table)1-1.
  2. 通過ON進行篩選, 在虛擬表vt1-1的基礎上進行篩選, 得到虛擬表vt1-2.
  3. 添加外部行. 如果使用的是左連接、右連接或者是全連接, 就會涉及外部行, 也就是虛擬表v1-2的基礎上增加外部行, 得到虛擬表vt1-3.

兩張以上的表, 會重覆上面的步驟, 直到所有的表都被處理完成, 這個過程得到的最後結論就是現在的原始數據.

拿到原始數據之後, 就可以在這個基礎上再進行WHERE階段了. 這個過程會再次得到一個虛擬表,假設為vt2.

之後進入第三步和第四步, 也就是GROUP BY和HAVING階段, 在vt2上進行分組和分組過濾, 得到中間的虛擬表vt3.

上面篩序就完成了, 接下來進入到SELECT階段, 當然, 是先查詢出所需要的列(欄位), 之後就會進入到DISTINCT階段, 這個也是兩個階段, 也會產生虛擬表.

欄位選擇並過濾重覆之後就會進入到ORDER BY階段進行排序, 再次得到虛擬表.

最後進入LIMIT階段, 得到最終的結果.

在一條SQL中, 不存在的關鍵字, 中間的那部分階段就會省略, 這些就是底層的原理.(疑惑是查詢欄位會使用到別名這些, 這些又是如何識別的呢?)

COUNT(*)的優化
  1. 一般情況下:COUNT(*) = COUNT(1) > COUNT(欄位), 所以儘量使用COUNT(*),當然如果你要統計的是就是某個欄位的非空數據行數,那另當別論。畢竟執行效率比較的前提是要結果一樣才行。
  2. 如果要統計COUNT(*),儘量在數據表上建立二級索引,系統會自動採用key_len小的二級索引進行掃描,這樣當我們使用SELECT COUNT(*)的時候效率就會提升,有時候提升幾倍甚至更高都是有可能的。

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

-Advertisement-
Play Games
更多相關文章
  • [TOC] 第一部分: 虛擬機創建、系統安裝、Linux歷史介紹 1.超級用戶(管理員用戶)提示符是 ,普通用戶提示符是` 2. linux關機重啟的命令有哪些 ? 3.bash是什麼? 4.bash特性, 常見的bash特性有哪些? 5.網卡的配置文件路徑什麼? 6.echo命令的功能是什麼? 7 ...
  • Linux的/proc/sys/fs/file max決定了當前內核可以打開的最大的文件句柄數。 查看當前的值: 這個值在kernel的文檔里是這樣描述的: 意思是file max一般為記憶體大小(KB)的10%來計算,如果使用shell,可以這樣計算: 一般我們不需要主動設置這個值,除非這個值確實較 ...
  • 初步區分和理解semaphore(信號量), event(事件), lock/mutex(鎖), condition ...
  • 上一篇博文,我們介紹了LCD RGB控制模式的典型時鐘。那麼這一片我們要詳細的去討論剩下的細節部分。 我們先回顧一下之前的典型時序圖 在這個典型的時序圖裡面,除了上篇博文講述的HSYNC VSYNC VDEN VCLK這幾信號外,我們還能看見諸如HSPW、 VSPW,HBPD、 HFPD,VBPD、 ...
  • 一、安裝使用Docer CE 本文以CentOS 7為例,安裝docker CE版本,docker有兩種版本,社區版本CE和企業版本EE,此處學習研究以CE版本為例, 兩種安裝方式可選:1、使用yum安裝,2、使用腳本自動安裝 系統要求 Docker CE 支持 64 位版本 CentOS 7,並且 ...
  • [TOC] 由於標準的ab只支持對單個uri進行壓測,不滿足實際需要,故做以下修改,使ab支持multi url。 1、下載Apache httpd相關源碼包以及針對ab工具的patch包 ~~~ wget https://mirrors.tuna.tsinghua.edu.cn/apache/ap ...
  • 感謝有奉獻精神的人 轉自:http://www.jb51.net/article/97157.htm 1 查看CPU 1.1 查看CPU個數 # cat /proc/cpuinfo | grep "physical id" | uniq | wc -l 2 **uniq命令:刪除重覆行;wc –l命 ...
  • 這是office受保護視圖導致的原因所造成的,按照以下操作,問題就不是問題了 解決辦法如下: 1、在打開excel2018數據表格時,出現提示“文件已損壞,無法打開”,點擊確定按鈕 2、進入空白程式界面後,在空白程式左上角點擊文件選項 3、在左側欄目文件菜單中點擊最下麵的“選項” 4、在彈出的視窗中 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...