来来来!一次搞定各种数据库 SQL 执行计划:MySQL、Oracle
執行計劃(execution plan,也叫查詢計劃或者解釋計劃)是數據庫執行 SQL 語句的具體步驟,例如通過索引還是全表掃描訪問表中的數據,連接查詢的實現方式和連接的順序等。如果 SQL 語句性能不夠理想,我們首先應該查看它的執行計劃。本文主要介紹如何在各種數據庫中獲取和理解執行計劃,并給出進一步深入分析的參考文檔。
現在許多管理和開發工具都提供了查看圖形化執行計劃的功能,例如 MySQL Workbench、Oracle SQL Developer、SQL Server Management Studio、DBeaver 等;不過我們不打算使用這類工具,而是介紹利用數據庫提供的命令查看執行計劃。
我們先給出在各種數據庫中查看執行計劃的一個簡單匯總:
| MySQL | EXPLAIN sql_statement; |
| Oracle | EXPLAIN PLAN FOR sql_statement; SELECT * FROM TABLE(DBMS_XPLAN.display); |
| SQL Server | SET STATISTICS PROFILE ON; sql_statement; SET STATISTICS PROFILE OFF; |
| PostgreSQL | EXPLAIN sql_statement; |
| SQLite | EXPLAIN QUERY PLAN sql_statement; |
MySQL 執行計劃
MySQL 中獲取執行計劃的方法很簡單,就是在 SQL 語句的前面加上EXPLAIN關鍵字:
執行該語句將會返回一個表格形式的執行計劃,包含了 12 列信息:
id|select_type|table|partitions|type |possible_keys |key |key_len|ref |rows|filtered|Extra | --|-----------|-----|----------|------|-----------------|-------|-------|--------------------|----|--------|-----------|1|SIMPLE |e | |ALL |emp_department_ix| | | | 107| 33.33|Using where|1|SIMPLE |d | |eq_ref|PRIMARY |PRIMARY|4 |hrdb.e.department_id| 1| 100| |MySQL 中的EXPLAIN支持 SELECT、DELETE、INSERT、REPLACE 以及 UPDATE 語句。
Oracle 執行計劃
Oracle 中提供了多種查看執行計劃的方法,本文使用以下方式:
使用EXPLAIN PLAN FOR命令生成并保存執行計劃;
顯示保存的執行計劃。
首先,生成執行計劃:
EXPLAIN PLAN FOR命令不會運行 SQL 語句,因此創建的執行計劃不一定與執行該語句時的實際計劃相同。
該命令會將生成的執行計劃保存到全局的臨時表 PLAN_TABLE 中,然后使用系統包 DBMS_XPLAN 中的存儲過程格式化顯示該表中的執行計劃。以下語句可以查看當前會話中的最后一個執行計劃:
SELECT * FROM TABLE(DBMS_XPLAN.display); PLAN_TABLE_OUTPUT | --------------------------------------------------------------------------------------------| Plan hash value: 1343509718 || --------------------------------------------------------------------------------------------| | Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time || --------------------------------------------------------------------------------------------| | 0 | SELECT STATEMENT | | 44 | 1672 | 6 (17)| 00:00:01 || | 1 | MERGE JOIN | | 44 | 1672 | 6 (17)| 00:00:01 || | 2 | TABLE ACCESS BY INDEX ROWID| DEPARTMENTS | 27 | 432 | 2 (0)| 00:00:01 || | 3 | INDEX FULL SCAN | DEPT_ID_PK | 27 | | 1 (0)| 00:00:01 || |* 4 | SORT JOIN | | 44 | 968 | 4 (25)| 00:00:01 || |* 5 | TABLE ACCESS FULL | EMPLOYEES | 44 | 968 | 3 (0)| 00:00:01 || --------------------------------------------------------------------------------------------|| Predicate Information (identified by operation id): | --------------------------------------------------- ||4 - access("E"."DEPARTMENT_ID"="D"."DEPARTMENT_ID") |filter("E"."DEPARTMENT_ID"="D"."DEPARTMENT_ID") |5 - filter("E"."SALARY">15000) |Oracle 中的EXPLAIN PLAN FOR支持 SELECT、UPDATE、INSERT 以及 DELETE 語句。
總結
以上是生活随笔為你收集整理的来来来!一次搞定各种数据库 SQL 执行计划:MySQL、Oracle的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: npm ERR! Failed at t
- 下一篇: rem与px的转换