java获取mysql执行计划_好程序员Java学习路线之MySQL的执行计划
好程序員
Java
學(xué)習(xí)路線之
MySQL
的執(zhí)行計(jì)劃。什么是執(zhí)行計(jì)劃?
執(zhí)行計(jì)劃通常是開(kāi)發(fā)者優(yōu)化
SQL
語(yǔ)句的第一步。
MySQL
在解析
SQL
語(yǔ)句時(shí),會(huì)生成多套執(zhí)行方案,然后內(nèi)部會(huì)進(jìn)行一個(gè)成本的計(jì)算,然后通過(guò)優(yōu)化器選擇一個(gè)最優(yōu)的方案執(zhí)行,然后根據(jù)這個(gè)方案會(huì)生成一個(gè)執(zhí)行計(jì)劃。開(kāi)發(fā)者通過(guò)查看
SQL
語(yǔ)句的執(zhí)行計(jì)劃,可以直觀的了解到
MySQL
是如何解析執(zhí)行這條
SQL
語(yǔ)句的,然后再針對(duì)性的進(jìn)行優(yōu)化。
如何查看
SQL
語(yǔ)句的執(zhí)行計(jì)劃?
語(yǔ)法:
explain ?select
語(yǔ)句
;
執(zhí)行計(jì)劃每個(gè)字段的含義:
id
(重要)
:主要用來(lái)標(biāo)識(shí)
SQL
語(yǔ)句的解析執(zhí)行順序
id
相同的情況:
id
不同的情況:
id
相同不同同時(shí)存在:
id
為
null
的情況:
比較少見(jiàn),
id
為
null
的部分一定是最后執(zhí)行的
select_type:主要用來(lái)標(biāo)識(shí)當(dāng)前查詢的類(lèi)型
mysql
查詢的分類(lèi):
簡(jiǎn)單查詢:沒(méi)有子查詢以及
union
的
sql
復(fù)雜查詢:
where
和
select
后面有子查詢
from
后面有子查詢
包換
union
關(guān)鍵字
SIMPLE
:標(biāo)識(shí)當(dāng)前查詢是一個(gè)簡(jiǎn)單查詢
PRIMARY
:如果是一個(gè)復(fù)雜查詢(子查詢或者
union
),則最外層的
SQL
語(yǔ)句會(huì)被標(biāo)記成這個(gè)類(lèi)型
SUBQUERY
:用來(lái)標(biāo)記一個(gè)子查詢(
where
、
select
)
注意:通常來(lái)說(shuō)被標(biāo)記成
PRIMARY
的部分,是最后執(zhí)行的部分
DERIVED
:用來(lái)標(biāo)記一個(gè)衍生查詢(
from
后面的子查詢)
UNION
:標(biāo)記
union
關(guān)鍵字后面的查詢部分
UNION RESULT
:標(biāo)記
union
結(jié)果的合并部分
type(
重要
)
:用來(lái)標(biāo)識(shí)當(dāng)前這條
SQL
語(yǔ)句是用哪種方式訪問(wèn)的數(shù)據(jù)行(最差
->
最優(yōu))
all
:表示當(dāng)前
MySQL
是采用全表掃描的方式訪問(wèn)的數(shù)據(jù)行
index
:表示當(dāng)前是按照全索引掃描的方式訪問(wèn)所有數(shù)據(jù)行
range
:表示查詢了索引的某個(gè)范圍
ref
:表示查詢了索引的某個(gè)值,但是這個(gè)值是可能重復(fù)的(只會(huì)出現(xiàn)在非唯一性索引的字段上)
eq_ref
:表示查詢了索引的某個(gè)值,但是這個(gè)值是唯一的(只會(huì)出現(xiàn)在主鍵、唯一性索引上,并且需要結(jié)合連接查詢)
const
:查詢索引的某個(gè)唯一性值,
mysql
會(huì)將這個(gè)條件優(yōu)化成一個(gè)常量
system
(正式開(kāi)發(fā)基本不會(huì)出現(xiàn)):表示
mysql
可以確定查詢的表結(jié)果一定只有一條
null
(性能最好,但是作用不大):表示當(dāng)前
SQL
語(yǔ)句直接在解析時(shí)就能獲得結(jié)果,不能去查詢記錄行
注意:通常在實(shí)際開(kāi)發(fā)過(guò)程中,需要將
SQL
語(yǔ)句優(yōu)化到
range
以上的級(jí)別,但是一定要具體問(wèn)題具體分析,有些時(shí)候
all
反而是更好的行為。
possible_keys
:用來(lái)標(biāo)記當(dāng)前這條
SQL
語(yǔ)句可能用上的索引列表
key
(重要)
:用來(lái)標(biāo)識(shí)當(dāng)前這個(gè)
SQL
語(yǔ)句用上了哪個(gè)索引
注意:有可能一個(gè)索引出現(xiàn)在
possible_keys
中,但是沒(méi)有出現(xiàn)在
key
中;也有可能一個(gè)索引出現(xiàn)在
key
中,但是沒(méi)有出現(xiàn)在
possible_keys
中。
explain select * from student force index(idx_age) order by age;
標(biāo)識(shí)手動(dòng)設(shè)置
MySQL
執(zhí)行的索引,但是最好不要這么干
key_len:標(biāo)識(shí)當(dāng)前使用到的索引長(zhǎng)度,這個(gè)值越大,說(shuō)明越多的條件使用上了索引
rows(
重要
)
:表示當(dāng)前查詢可能訪問(wèn)的記錄行數(shù),這個(gè)值越小越好,最好顯示
1
注意:通常在實(shí)際的優(yōu)化過(guò)程中,需要參考
type
和
rows
兩個(gè)字段來(lái)決定是否需要進(jìn)行優(yōu)化。
比如
type
為
all
,但是
rows
為
1
,這種情況下,其實(shí)完全無(wú)需優(yōu)化。
比如
type
為
ref,
但是
rows
為
10W
,那么這條
sql
語(yǔ)句性能肯定比不上
all - 1
Extra(
重要
)
:表示當(dāng)前一些額外的信息顯示的地方
Using index
:說(shuō)明當(dāng)前的執(zhí)行計(jì)劃用上了覆蓋索引。
Using temporary
:說(shuō)明當(dāng)前內(nèi)部使用了臨時(shí)表
(
分組、排序
)
Using filesort
:說(shuō)明使用了文件排序,這個(gè)排序有可能在內(nèi)存上排序,也有可能在硬盤(pán)上排序,如果是在硬盤(pán)上排序,則最好優(yōu)化一下(比如通過(guò)索引進(jìn)行排序)
Using where
:表示使用了過(guò)濾條件
總結(jié)
以上是生活随笔為你收集整理的java获取mysql执行计划_好程序员Java学习路线之MySQL的执行计划的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 脂20多少钱啊?
- 下一篇: mysql.sock 111,错误200