java獲取mysql執行計劃_好程序員Java學習路線之MySQL的執行計劃

好程序員

Java

學習路線之

MySQL

的執行計劃。什么是執行計劃?

執行計劃通常是開發者優化

SQL

語句的第一步。

MySQL

在解析

SQL

語句時,會生成多套執行方案,然后內部會進行一個成本的計算,然后通過優化器選擇一個最優的方案執行,然后根據這個方案會生成一個執行計劃。開發者通過查看

SQL

語句的執行計劃,可以直觀的了解到

MySQL

是如何解析執行這條

SQL

語句的,然后再針對性的進行優化。

如何查看

SQL

語句的執行計劃?

語法:

explain ?select

語句

;

執行計劃每個字段的含義:

id

(重要)

:主要用來標識

SQL

語句的解析執行順序

id

相同的情況:

807b375b1c5ad7967017d324745c7eca.png

id

不同的情況:

d2be94b851fba5ea043ae371478cbc04.png

id

相同不同同時存在:

6bd8790628c18d9ed35d145940f8f580.png

id

null

的情況:

比較少見,

id

null

的部分一定是最后執行的

select_type:主要用來標識當前查詢的類型

mysql

查詢的分類:

簡單查詢:沒有子查詢以及

union

sql

復雜查詢:

where

select

后面有子查詢

from

后面有子查詢

包換

union

關鍵字

SIMPLE

:標識當前查詢是一個簡單查詢

PRIMARY

:如果是一個復雜查詢(子查詢或者

union

),則最外層的

SQL

語句會被標記成這個類型

SUBQUERY

:用來標記一個子查詢(

where

select

)

注意:通常來說被標記成

PRIMARY

的部分,是最后執行的部分

DERIVED

:用來標記一個衍生查詢(

from

后面的子查詢)

UNION

:標記

union

關鍵字后面的查詢部分

UNION RESULT

:標記

union

結果的合并部分

type(

重要

)

:用來標識當前這條

SQL

語句是用哪種方式訪問的數據行(最差

->

最優)

all

:表示當前

MySQL

是采用全表掃描的方式訪問的數據行

index

:表示當前是按照全索引掃描的方式訪問所有數據行

range

:表示查詢了索引的某個范圍

ref

:表示查詢了索引的某個值,但是這個值是可能重復的(只會出現在非唯一性索引的字段上)

eq_ref

:表示查詢了索引的某個值,但是這個值是唯一的(只會出現在主鍵、唯一性索引上,并且需要結合連接查詢)

const

:查詢索引的某個唯一性值,

mysql

會將這個條件優化成一個常量

system

(正式開發基本不會出現):表示

mysql

可以確定查詢的表結果一定只有一條

null

(性能最好,但是作用不大):表示當前

SQL

語句直接在解析時就能獲得結果,不能去查詢記錄行

注意:通常在實際開發過程中,需要將

SQL

語句優化到

range

以上的級別,但是一定要具體問題具體分析,有些時候

all

反而是更好的行為。

possible_keys

:用來標記當前這條

SQL

語句可能用上的索引列表

key

(重要)

:用來標識當前這個

SQL

語句用上了哪個索引

注意:有可能一個索引出現在

possible_keys

中,但是沒有出現在

key

中;也有可能一個索引出現在

key

中,但是沒有出現在

possible_keys

中。

explain select * from student force index(idx_age) order by age;

標識手動設置

MySQL

執行的索引,但是最好不要這么干

key_len:標識當前使用到的索引長度,這個值越大,說明越多的條件使用上了索引

rows(

重要

)

:表示當前查詢可能訪問的記錄行數,這個值越小越好,最好顯示

1

注意:通常在實際的優化過程中,需要參考

type

rows

兩個字段來決定是否需要進行優化。

比如

type

all

,但是

rows

1

,這種情況下,其實完全無需優化。

比如

type

ref,

但是

rows

10W

,那么這條

sql

語句性能肯定比不上

all - 1

Extra(

重要

)

:表示當前一些額外的信息顯示的地方

Using index

:說明當前的執行計劃用上了覆蓋索引。

Using temporary

:說明當前內部使用了臨時表

(

分組、排序

)

Using filesort

:說明使用了文件排序,這個排序有可能在內存上排序,也有可能在硬盤上排序,如果是在硬盤上排序,則最好優化一下(比如通過索引進行排序)

Using where

:表示使用了過濾條件

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/376057.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/376057.shtml
英文地址,請注明出處:http://en.pswp.cn/news/376057.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Web系統開發構架再思考-前后端的完全分離

前言 前后端完全分離其實一直是Web開發人員的夢想,也一直是我的夢想,遙想當年,無論是直接在代碼里面輸出HTML,還是在HTML里面嵌入各種代碼,都不能讓人感到滿意.期間的痛苦和糾結,我想所有Web開發人員都深有感觸. 由于最近幾年一直在MS平臺,從Web Form到MVC,MS平臺雖然易用好學,…

C++程序設計基礎

01 1 預編譯常用的有&#xff0c;宏定義和包含庫。2 庫&#xff1a;是實用工具的集和&#xff0c;由程序員編寫&#xff0c;可以完成一些特定的功能。3 <> 系統庫 ""用戶自定義庫。4 宏定義&#xff1a;定義符號常量&#xff0c;符號常量就是給常量取的名字。常…

文科思維Java_開源之Processing:這好玩的編程語言是為文科生藝術家準備的

說起編程語言&#xff0c;我們很多時候第一反應就是很難&#xff0c;都是理工科計算機相關行業的人才學的&#xff0c;都是為理科生掉頭發準備的。的確&#xff0c;計算機的嚴謹&#xff0c;注定要求開發應用的人有縝密的理工科的理性邏輯思維&#xff0c;然而一人客從另一方面…

第一章導言的筆記與思考

Writer&#xff1a;BYSocket&#xff08;泥沙磚瓦漿木匠&#xff09; 微博&#xff1a;BYSocket 豆瓣&#xff1a;BYSocket ~&#xff1a;較重要 ~~&#xff1a;重要 1.1 hello&#xff0c;world ~初學人來說還是一大障礙&#xff0c;手寫編寫程序文本&#xff0c;然后成功的進…

C 和 Object- C 中得 #ifdef 和#ifndef

很多宏是為了進行條件編譯。一般情況下&#xff0c;源程序中所有的行都參加編譯。但是有時希望對其中一部分內容只在滿足一定條件才進行編譯&#xff0c;也就是對一部分內容指定編譯的條件&#xff0c;這就是“條件編譯”。有時&#xff0c;希望當滿足某條件時對一組語句進行編…

C語言基礎小齋

一、C語言數據類型 ok&#xff0c;如我們所知&#xff0c;C語言作為大學工科專業的必學課程&#xff0c;其重要性不言而喻&#xff1b;它為我們提供了豐富的數據類型&#xff0c;所以它很適合程序員來編寫 數據庫 &#xff0c;如DB2、Oracale都是C語言編寫的。 那么C語言具體又…

《Cracking the Coding Interview》——第11章:排序和搜索——題目8

2014-03-21 22:23 題目&#xff1a;假設你一開始有一個空數組&#xff0c;你在讀入一些整數并將其插入到數組中&#xff0c;保證插入之后數組一直按升序排列。在讀入的過程中&#xff0c;你還可以進行一種操作&#xff1a;查詢某個值val是否存在于數組中&#xff0c;并給出這個…

gradle打包java項目_gradle打包java項目

轉載地址&#xff1a;http://www.gfzj.us/series/gradle/2014/12/12/gradle%E5%B0%8F%E7%B3%BB%E5%88%97(4)--gradle%E6%89%93%E5%8C%85java%E9%A1%B9%E7%9B%AE.html以gradle小系列所舉例子為示例&#xff0c;在此處介紹兩種gradle發布java項目的方法&#xff1a;fat jar方式該…

堡壘機2.0

一、編輯系統環境變量&#xff0c;讓用戶登錄后自動調用腳本 1 vim /etc/profile 2 python /baolei/ssh_login.py 3 # 判斷登錄用戶是否為 root 用戶&#xff0c;root用戶退出程序不進行logout操作&#xff0c;否則則logout 4 if [ $? ! 10 ];then 5 echo "Good …

Flex中利用ByteArray與BitmapData互相轉換實現圖片的二進制保存與復原

Flex中利用ByteArray與BitmapData互相轉換實現圖片的二進制保存與復原 近 日在項目當中需要將圖片保存到共享對象當中&#xff0c;開始用了倆天的時間做了對象的序列化&#xff0c;并以BitmapData的形式進行了圖片的序列化保存共享&#xff0c;因為系統 沒有提供更好的接口所以…

java8自定義收集器_使用自定義收集器進行Java 8分組?

我有以下課程。class Person {String name;LocalDate birthday;Sex gender;String emailAddress;public int getAge() {return birthday.until(IsoChronology.INSTANCE.dateNow()).getYears();}public String getName() {return name;}}我希望能夠按年齡分組&#xff0c;然后收…

poj 1862 Stripies/優先隊列

原題鏈接&#xff1a;http://poj.org/problem?id1862 簡單題&#xff0c;貪心優先隊列主要練習一下stl大根堆 寫了幾種實現方式寫成類的形式還是要慢一些。。。 手打的heap&#xff1a; 1&#xff1a; 1 #include<cstdio>2 #include<cstdlib>3 #include<cmath&…

java url下載ics_使用Microsoft Graph API處理外部(Internet / .ics)日歷URL

在新的Graph API中&#xff0c;是否可以根據外部.ics日歷網址為用戶創建新日歷&#xff1f;我d like to do is to use a daemon to inject a link to an external calendar into the list of calendars a user has if they don已經有了這樣一個鏈接 . 這將有效地復制用戶可以在…

命令行生成jar文件

1.打開cmd&#xff0c;進入編譯完后所有類的當前目錄 命令行 jar -cvf javaname.jar *.class 這時已經生成了 javaname.jar 不過如果有多個類&#xff0c;雙擊打不開 2.解壓javaname.jar 進入META-INF&#xff0c;編輯MANIFEST.MF: 尾行寫入Main-Class:&#xff08;&…

Github鏈接地址

https://github.com/kzj1/test轉載于:https://www.cnblogs.com/lalal/p/4456923.html

java foreach和for循環區別_java相關:老生常談foreach(增強for循環)和for的區別

java相關&#xff1a;老生常談foreach(增強for循環)和for的區別發布于 2020-8-18|復制鏈接下面小妖就為大家帶來一篇老生常談foreach(增強for循環)和for的區別。小妖覺得挺不錯的&#xff0c;現在就分享給大家&#xff0c;也給大家做個參考。一起跟隨小妖過來看看吧首先說一下f…

關于事件冒泡和捕獲的問題

由于習慣于jquery的方便操作&#xff0c;往往讓我們慢慢淡忘了原生js應有的功能和屬性&#xff0c;今天重溫一下事件冒泡和捕獲問題。 冒泡&#xff1a;從內向外&#xff0c;如&#xff1a;div > body > html (不同瀏覽器稍有不同) 捕獲&#xff1a;從外向內&#xff0c;…

root無法運行命令解決辦法

今天運行一個命令wget(wg再使用tab鍵無法使用)&#xff0c;如下提示 -bash: /usr/bin/wget: 權限不夠 [rootwww /]# ls -Z /usr/bin/wget-rw-r--r--. root root system_u:object_r:bin_t:s0 /usr/bin/wget發現沒有執行權限 chmod x /usr/bin/wget -bash: /usr/bin/wget: …

java類編寫sql_用JavaBean編寫SQL Server數據庫連接類

以下為引用的內容&#xff1a;//類conn.db.conndb.javapackage conn.db;import java.sql.*;public class conndb {Connection conn;ResultSet rs;private int count;public conndb() {try {Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");} catch (Exception ex) {}…

ASP.NET中Request.ApplicationPath、Request.FilePath、Request.Path、.Request.MapPath、

1.Request.ApplicationPath->當前應用的目錄 Jsp中, ApplicationPath指的是當前的application(應用程序)的目錄,ASP.NET中也是這個意思。 對應的--例如我的服務器上有兩個web應用域名都是mockte.com 一個映射到目錄mockte.com/1/ 另一個影射到 http://mockte.com/2/ …