日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

来来来!一次搞定各种数据库 SQL 执行计划:MySQL、Oracle

發布時間:2024/9/27 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 来来来!一次搞定各种数据库 SQL 执行计划:MySQL、Oracle 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.


執行計劃(execution plan,也叫查詢計劃或者解釋計劃)是數據庫執行 SQL 語句的具體步驟,例如通過索引還是全表掃描訪問表中的數據,連接查詢的實現方式和連接的順序等。如果 SQL 語句性能不夠理想,我們首先應該查看它的執行計劃。本文主要介紹如何在各種數據庫中獲取和理解執行計劃,并給出進一步深入分析的參考文檔。

現在許多管理和開發工具都提供了查看圖形化執行計劃的功能,例如 MySQL Workbench、Oracle SQL Developer、SQL Server Management Studio、DBeaver 等;不過我們不打算使用這類工具,而是介紹利用數據庫提供的命令查看執行計劃。

我們先給出在各種數據庫中查看執行計劃的一個簡單匯總:

數據庫執行計劃
MySQLEXPLAIN sql_statement;
OracleEXPLAIN PLAN FOR sql_statement;
SELECT * FROM TABLE(DBMS_XPLAN.display);
SQL ServerSET STATISTICS PROFILE ON;
sql_statement;
SET STATISTICS PROFILE OFF;
PostgreSQLEXPLAIN sql_statement;
SQLiteEXPLAIN QUERY PLAN sql_statement;

MySQL 執行計劃
MySQL 中獲取執行計劃的方法很簡單,就是在 SQL 語句的前面加上EXPLAIN關鍵字:

EXPLAIN SELECT e.first_name,e.last_name,e.salary,d.department_nameFROM employees eJOIN departments d ON (e.department_id = d.department_id)WHERE e.salary > 15000;

執行該語句將會返回一個表格形式的執行計劃,包含了 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 SELECT e.first_name,e.last_name,e.salary,d.department_nameFROM employees eJOIN departments d ON (e.department_id = d.department_id)WHERE e.salary > 15000;

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的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。