MySQL最佳化之如何查詢SQL效率低的原因
查詢到效率低的 SQL 語句 後,可以透過 EXPLAIN 或者 DESC 命令獲取 MySQL 如何執行 SELECT 語句的資訊,包括在 SELECT 語句執行過程中表如何連線和連線的順序,比如我們想計算 2006 年所有公司的銷售額,需要關聯 sales 表和 company 表,並且對 profit 欄位做求和( sum )操作,相應 SQL 的執行計劃如下:
mysql> explain select sum(profit) from sales a,company b where a.company_id = b.id and a.year = 2006G;
*************************** 1. row ***************************
id: 1
select_type: SIMPLE
table: a
type: ALL
possible_keys: NULL
key: NULL
key_len: NULL
ref: NULL
rows: 12
Extra: Using where
*************************** 2. row ***************************
id: 1
select_type: SIMPLE
table: b
type: ALL
possible_keys: NULL
key: NULL
key_len: NULL
ref: NULL
rows: 12
Extra: Using where
2 rows in set (0.00 sec)
每個列的解釋如下:
•select_type :表示 SELECT 的 型別,常見的取值有 SIMPLE (簡單表,即不使用表連線或者子查詢)、 PRIMARY (主查詢,即外層的查詢)、 UNION ( UNION 中的第二個或者後面的查詢語句)、 SUBQUERY (子查詢中的第一個 SELECT )等。
•table :輸出結果集的表。
•type :表示表的連線型別,效能由好到差的連線型別為 system (表中僅有一行,即常量表)、 const (單表中最多有一個匹配行,例如 primary key 或者 unique index )、 eq_ref (對於前面的每一行,在此表中只查詢一條記錄,簡單來說,就是多表連線中使用 primary key 或者 unique index )、 ref (與 eq_ref 類似,區別在於不是使用 primary key 或者 unique index ,而是使用普通的索引)、 ref_or_null ( 與 ref 類似,區別在於條件中包含對 NULL 的查詢 ) 、 index_merge ( 索引合併最佳化 ) 、 unique_subquery ( in 的後面是一個查詢主鍵欄位的子查詢)、 index_subquery ( 與 unique_subquery 類似,區別在於 in 的後面是查詢非唯一索引欄位的子查詢)、 range (單表中的範圍查詢)、 index (對於前面的每一行,都透過查詢索引來得到資料)、 all (對於前面的每一行,都透過全表掃描來得到資料)。
•possible_keys :表示查詢時,可能使用的索引。
•key :表示實際使用的索引。
•key_len :索引欄位的長度。
•rows :掃描行的數量。
•Extra :執行情況的說明和描述。
在上面的例子中,已經可以確認是 對 a 表的全表掃描導致效率的不理想,那麼 對 a 表的 year 欄位建立索引,具體如下:
mysql> create index idx_sales_year on sales(year);
Query OK, 12 rows affected (0.01 sec)
Records: 12 Duplicates: 0 Warnings: 0
建立索引後,這條語句的執行計劃如下:
mysql> explain select sum(profit) from sales a,company b where a.company_id = b.id and a.year = 2006G;
*************************** 1. row ***************************
id: 1
select_type: SIMPLE
table: a
type: ref
possible_keys: idx_sales_year
key: idx_sales_year
key_len: 4
ref: const
rows: 3
Extra:
*************************** 2. row ***************************
id: 1
select_type: SIMPLE
table: b
type: ALL
possible_keys: NULL
key: NULL
key_len: NULL
ref: NULL
rows: 12
Extra: Using where
2 rows in set (0.00 sec)
可以發現建立索引後對 a 表需要掃描的行數明顯減少(從全表掃描減少到 3 行),可見索引的使用可以大大提高資料庫的訪問速度,尤其在表很龐大的時候這種優勢更為明顯,使用索引最佳化 sql 是最佳化問題 sql 的一種常用基本方法,在後面的章節中我們會具體介紹如何使索引來最佳化 sql 。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2618/viewspace-2810488/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- mysql查詢效率慢的SQL語句MySql
- 在mysql查詢效率慢的SQL語句MySql
- 十七、Mysql之SQL優化查詢MySql優化
- 談談MYSQL索引是如何提高查詢效率的MySql索引
- MySQL 如何最佳化大分頁查詢?MySql
- MySQL exists關聯子查詢SQL效能及其低下最佳化之等值子查詢轉換MySql
- MySQL查詢最佳化MySql
- MySQL分頁查詢offset過大,Sql最佳化經驗MySql
- [Mysql]慢查詢最佳化MySql
- MySQL查詢效能最佳化MySql
- 探究MySQL中SQL查詢的成本MySql
- 如何查詢Linux當機的原因?Linux
- MySQL:查詢欄位數量多少對查詢效率的影響MySql
- 盤點MySQL慢查詢的12個原因MySql
- openGauss SQL引擎(下)——查詢最佳化SQL
- 【GaussDB(for MySQL)】 Big IN查詢最佳化MySql
- 如何利用mysql5.7提供的虛擬列來提高查詢效率MySql
- sql查詢是如何執行的?SQL
- MySQL之連線查詢和子查詢MySql
- SQL查詢的:子查詢和多表查詢SQL
- 30個MySQL千萬級大資料SQL查詢最佳化技巧詳解MySql大資料
- SQL 查詢 exist join in 的用法和相應的適用場景 (最佳化查詢)SQL
- Mysql之查詢語句MySql
- 技術分享 | MySQL Binlog 通過 MySQL 客戶端匯入資料庫效率低的原因MySql客戶端資料庫
- MySQL-10.索引最佳化與查詢最佳化MySql索引
- 《MySQL慢查詢優化》之SQL語句及索引優化MySql優化索引
- MySQL查詢最佳化的5個實用技巧MySql
- MySQL索引原理及慢查詢最佳化MySql索引
- MongoDB 如何支援類 SQL 查詢MongoDBSQL
- MySQL 優化五(關聯查詢子查詢以及 in 的效率問題)(高階篇)MySql優化
- MySQL學習(三) SQL基礎查詢MySql
- UData查詢引擎最佳化-如何讓一條SQL效能提升數倍SQL
- MySQL information_schema.columns表查詢慢原因分析MySqlORM
- 【SQL】Oracle查詢轉換之 OR用法SQLOracle
- MySQL 查詢效能分析之 ExplainMySqlAI
- 【SQL】Oracle查詢轉換之物化檢視查詢重寫SQLOracle
- Java 中如何使用 SQL 查詢 TXTJavaSQL
- MySQL資料庫詳解(一)SQL查詢語句是如何執行的?MySql資料庫