搜尋
首頁資料庫SQLsql執行順序是什麼

sql執行順序是什麼

Jun 10, 2019 am 10:36 AM

sql執行順序是什麼

SQL語句的執行順序

#MySQL的語句一共分為11步,如下圖所標註的那樣,最先執行的總是FROM操作,最後執行的是LIMIT操作。其中每一個操作都會產生一張虛擬的表,這個虛擬的表作為一個處理的輸入,只是這些虛擬的表對用戶來說是透明的,但是只有最後一個虛擬的表才會被作為結果返回。如果沒有在語句中指定某一個子句,那麼將會跳過對應的步驟。

下面我們來具體分析一下查詢處理的每一個階段

FORM: 對FROM的左邊的表和右邊的表計算笛卡爾積。產生虛表VT1

ON: 對虛表VT1進行ON篩選,只有那些符合的行才會被記錄在虛表VT2中。

JOIN: 如果指定了OUTER JOIN(例如left join、 right join),那麼保留表中未匹配的行就會作為外部行添加到虛擬表VT2中,產生虛擬表VT3, rug from子句包含兩個以上的表的話,那麼就會對上一個join連接產生的結果VT3和下一個表重複執行步驟1~3這三個步驟,一直到處理完所有的表為止

WHERE: 對虛擬表VT3進行WHERE條件過濾。只有符合的記錄才會插入到虛擬表VT4中。

GROUP BY: 根據group by子句中的列,將VT4中的記錄進行分組操作,產生VT5.

CUBE | ROLLUP: 對錶VT5進行cube或rollup操作,產生表VT6.

HAVING: 將虛擬表VT6套用having過濾,只有符合的記錄才會被插入到虛擬表VT7中。

SELECT: 執行select操作,選擇指定的列,插入到虛擬表VT8中。

DISTINCT: 對VT8中的記錄進行去重。產生虛擬表VT9.

ORDER BY: 將虛擬表VT9中的記錄依照進行排序操作,產生虛擬表VT10.

LIMIT:取出指定行的記錄,產生虛擬表VT11, 並將結果傳回。

寫的順序:select ... from... where.... group by... having... order by.. limit [offset,] 

(rows)

執行順序:from... where...group by... having.... select ... order by... limit

以上是sql執行順序是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
OLTP與OLAP:那大數據呢?OLTP與OLAP:那大數據呢?May 14, 2025 am 12:06 AM

Oltpandolaparebothestential forbigdata:oltphandlesleal-timetransactions,whereLapanalyzeslargedAtasetset.1)Oltprequirescalingcalingtechnologieslikenosqlforbigdata

SQL中的模式匹配是什麼?它如何工作?SQL中的模式匹配是什麼?它如何工作?May 13, 2025 pm 04:09 PM

patternMatchingInsqlusestHelikeOperatorAndRegulareSearchSearchForceSearchPatterns.itenablesflexibledataqueryingwithWildCardslike%and_,andregexforcomplexmatches.it'sversatilebutrequirescarefuilusetetoetoetoavovoidperformanceSissUseSissUseSuseSuseSuseSuseSuseSuseSuseSuseSuseSuseSuseDoveruse。

學習SQL:了解挑戰和獎勵學習SQL:了解挑戰和獎勵May 11, 2025 am 12:16 AM

學習SQL需要掌握基礎知識、核心查詢、複雜JOIN操作和性能優化。 1.理解表、行、列等基本概念和不同SQL方言。 2.熟練使用SELECT語句進行查詢。 3.掌握JOIN操作從多表獲取數據。 4.優化查詢性能,避免常見錯誤,使用索引和EXPLAIN命令。

SQL:揭示其目的和功能SQL:揭示其目的和功能May 10, 2025 am 12:20 AM

SQL的核心概念包括CRUD操作、查詢優化和性能提升。 1)SQL用於管理和操作關係數據庫,支持CRUD操作。 2)查詢優化涉及解析、優化和執行階段。 3)性能提升可以通過使用索引、避免SELECT*、選擇合適的JOIN類型和分頁查詢實現。

SQL安全最佳實踐:保護數據庫免受漏洞SQL安全最佳實踐:保護數據庫免受漏洞May 09, 2025 am 12:23 AM

防止SQL注入的最佳實踐包括:1)使用參數化查詢,2)輸入驗證,3)最小權限原則,4)使用ORM框架。通過這些方法,可以有效保護數據庫免受SQL注入和其他安全威脅。

MySQL:SQL的實際應用MySQL:SQL的實際應用May 08, 2025 am 12:12 AM

MySQL受歡迎的原因是其性能卓越且易於使用和維護。 1.創建數據庫和表:使用CREATEDATABASE和CREATETABLE命令。 2.插入和查詢數據:通過INSERTINTO和SELECT語句操作數據。 3.優化查詢:使用索引和EXPLAIN語句提升性能。

比較SQL和MySQL:語法和功能比較SQL和MySQL:語法和功能May 07, 2025 am 12:11 AM

SQL和MySQL的區別與聯繫如下:1.SQL是標準語言,用於管理關係數據庫,MySQL是基於SQL的數據庫管理系統。 2.SQL提供基本CRUD操作,MySQL在此基礎上增加了存儲過程、觸發器等功能。 3.SQL語法標準化,MySQL在某些地方有改進,如LIMIT用於限制返回行數。 4.使用示例中,SQL和MySQL的查詢語法略有不同,MySQL的JOIN和GROUPBY更直觀。 5.常見錯誤包括語法錯誤和性能問題,MySQL的EXPLAIN命令可用於調試和優化查詢。

SQL:初學者指南 - 學習容易嗎?SQL:初學者指南 - 學習容易嗎?May 06, 2025 am 12:06 AM

sqlisytolearnforbeginnersduetoitsstraightStraightSandAxandBasicCoperations,butmasteringItInVolvesComplexConcepts.1)startwithSimplequeriesLikeSlect,Insert,inters,Update,Update,update,deasts,delete.2)

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具