色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

MySql中sql語句執(zhí)行過程詳細(xì)講解

瀏覽:15日期:2023-02-18 16:43:45
目錄
  • 前言:
  • sql語句的執(zhí)行過程:
  • 查詢緩存:
  • 分析器:
  • 優(yōu)化器:
  • 執(zhí)行器:
  • 總結(jié)

前言:

很多人都在使用mysql數(shù)據(jù)庫,但是很少有人能夠說出來整個sql語句的執(zhí)行過程是怎樣的,如果不了解執(zhí)行過程的話,就很難進(jìn)行sql語句的優(yōu)化處理,也很難設(shè)計出來優(yōu)良的數(shù)據(jù)庫表結(jié)構(gòu)。這篇文章主要是講解一下sql語句的執(zhí)行過程。

sql語句的執(zhí)行過程:

客戶端、連接器、分析器、優(yōu)化器、執(zhí)行器、存儲引擎幾個階段。

連接器的作用:管理鏈接、權(quán)限驗證的處理。

分析器的作用:詞法分析、語法分析。

優(yōu)化器的作用:執(zhí)行計劃的生成、索引選擇。

執(zhí)行器的作用:操作引擎、返回結(jié)果。

存儲引擎的作用:存儲數(shù)據(jù)、提供讀寫接口。

另外的一個分支是,會進(jìn)行查詢緩存的操作,如果命中了緩存則直接返回的操作。

mysql可以分為server層和存儲引擎層兩個部分:

server層:

包括鏈接器、查詢緩存、分析器、優(yōu)化器、執(zhí)行器等,涵蓋Mysql的大多數(shù)核心服務(wù)功能,以及所有的內(nèi)置函數(shù)(日期、時間、數(shù)學(xué)、和加密函數(shù)等),所有的存儲引擎的功能都在這一部分實現(xiàn)的,比如說存儲過程、觸發(fā)器、視圖。

存儲引擎:

主要負(fù)責(zé)數(shù)據(jù)的存儲和提取,其架構(gòu)模式是插件式的,支持InnoDB、Memory等多個存儲引擎。最常用的是InnoDB,這個主要在Mysql5.5版本開始成為了默認(rèn)存儲引擎。

當(dāng)在執(zhí)行sql查詢的時候,如果不指定引擎類型、默認(rèn)使用的innoDB。當(dāng)然也可以指定存儲引擎類型進(jìn)行處理,比如說創(chuàng)建表的時候,可以把存儲引擎修改為memory,進(jìn)行表的創(chuàng)建出合理。當(dāng)然了,不同的存儲引擎的表數(shù)據(jù)存儲方式也是不一樣的。

連接器:

執(zhí)行sql語句的時候,第一步需要進(jìn)行數(shù)據(jù)庫的連接處理,連接器負(fù)責(zé)客戶端建立連接、獲取權(quán)限、維持和管理連接。

根據(jù)命令可以看出來,主要進(jìn)行幾個參數(shù)的輸入,IP地址、端口號、以及用戶名、密碼的處理。連接mysql是客戶端工具,用戶服務(wù)器建立連接,進(jìn)行tcp握手之后,連接器需要進(jìn)行身份的驗證,然后輸入用戶名、密碼。

密碼不對的時候,會收到一個“Access denied for user”的錯誤提示,然后客戶端結(jié)束執(zhí)行。

用戶名、密碼驗證通過之后,連接器就會開始進(jìn)行權(quán)限表查詢權(quán)限,然后進(jìn)行權(quán)限的操作處理。

連接完成之后,沒有進(jìn)行其他的操作,這個時候連接就處于空閑狀態(tài),show processlist。

客戶端如果長時間不操作的話,默認(rèn)的等待時間(wait_timeout)是八個小時。

數(shù)據(jù)庫建立連接是比較復(fù)雜的,建議在項目中盡量少的建立連接的操作,也就是說盡量使用長連接的處理。

在項目中經(jīng)常會遇到一種情況就是數(shù)據(jù)庫的長連接,很長時間不關(guān)閉的操作,這個時候會導(dǎo)致內(nèi)存的占用太大,被系統(tǒng)殺掉導(dǎo)致的Mysql的異常。

解決方案有下面兩種方案:

  • 定期斷開長連接,使用一段時間之后,比如說執(zhí)行一個占用內(nèi)存的大查詢之后,這個時候斷開連接,之后要查詢的話再重新連接。
  • 通過使用命令進(jìn)行重新初始化連接資源,這個時候需要重連,但是會把連接恢復(fù)到初始化的狀態(tài)。

查詢緩存:

連接建立完畢之后,進(jìn)行查詢緩存的處理,執(zhí)行sql語句會先到緩存中看看是不是剛剛執(zhí)行了這條語句,之前執(zhí)行過的語句及其結(jié)果就會以key-value對的形式直接存儲在內(nèi)存中的,key是查詢的語句,value是查詢的結(jié)果,如果查詢能夠直接在這個緩存中找到key,那么這個value可以直接返回給客戶端。

如果語句不在查詢緩存中的話,就會繼續(xù)后面的執(zhí)行階段,執(zhí)行完成后,執(zhí)行結(jié)果會被存入查詢緩存中。如果可以查詢到緩存的話,就不會進(jìn)行后面的復(fù)雜操作了,效率會高很多。

查詢緩存的弊端:

查詢緩存失敗一般情況下會比較頻繁,只要對一個表的進(jìn)行了更新的話,這個表上面所有的緩存就會被清空。因此一般情況下查詢緩存的命中率很低。一般情況下,一個系統(tǒng)的配置表或者靜態(tài)的表才會使用到查詢緩存的方式進(jìn)行處理。

分析器:

分析器首先會進(jìn)行詞法分析,輸入的是由多個字符串和空格組成的一條sql語句,mysql需要識別出來里面的字符串分別是什么,代表什么意思。

首先:mysql從輸入的select這個關(guān)鍵詞識別出來,這個是一個查詢的語句,需要把from關(guān)鍵字后面的,字符串t識別出來表名稱等等的操作。

然后進(jìn)行語法分析的處理,根據(jù)詞法分析,根據(jù)詞法分析的結(jié)果,語句分析器就會根據(jù)語法規(guī)則判斷輸入的這個sql語句是否滿足mysql的語法。

檢查出來錯誤提示如下圖:

一般提示錯誤的信息只會進(jìn)行第一個錯誤的位置。

優(yōu)化器:

經(jīng)過了分析器的處理,mysql就知道了該如何進(jìn)行優(yōu)化器的處理了,優(yōu)化器的處理邏輯是在表里面進(jìn)行多個索引的時候,決定使用那個索引,或者說在一個語句有多個關(guān)聯(lián)的時候,決定各個表的連接順序的情況,如下圖所示:

第一種執(zhí)行的結(jié)果是處理t1.c=10是否走索引,然后可以先判斷 一下邏輯的結(jié)果是否一樣,如果執(zhí)行的結(jié)果是一樣的話,可以任意選擇一種方案進(jìn)行處理。

執(zhí)行器:

  • 調(diào)用InNoDB引擎接口取這個表的第一行,判斷值是否10,如果是10進(jìn)行集中處理,否則的話就跳過。
  • 執(zhí)行器將遍歷過程中所有滿足條件的行組成的記錄集合返回給客戶端。

總結(jié)

到此這篇關(guān)于MySql中sql語句執(zhí)行過程詳細(xì)講解的文章就介紹到這了,更多相關(guān)MySql sql語句執(zhí)行過程內(nèi)容請搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: MySQL
主站蜘蛛池模板: 日韩精品欧美激情国产一区 | 一级aaaaaa毛片免费同男同女 | 韩国啪啪网站 | 日韩在线二区 | 国产美女在线精品观看 | 4tube高清性欧美 | 亚洲国产区 | 97超级碰碰碰碰在线视频 | 久久er热这里只有精品免费 | 黄在线看| 中文字幕一区二区在线视频 | 一区二区三区精品视频 | 宅男69免费永久网站 | 精品在线一区二区三区 | 中文字幕波多野不卡一区 | 99久久免费精品国产免费 | 91精品视频免费 | 成人精品视频在线观看 | 国产精品久久久久久久y | 亚洲精品国产第一区第二区国 | 国产综合成人久久大片91 | 欧美一区三区 | 日本a级毛片视频播放 | 欧美一级日本一级韩国一级 | 97香蕉久久夜色精品国产 | 大胆gogo999亚洲肉体艺术 | 99精品国产高清一区二区三区香蕉 | 一区二区三区在线 | 欧美高清在线视频在线99精品 | 精品国产美女福利到在线不卡 | 成人毛片免费网站 | 国产精品日韩专区 | 精品一区二区三区免费站 | 亚洲国产片 | 亚洲免费成人在线 | 亚洲看看| 极品美女户外勾搭无套 | 亚洲欧美一区二区三区四区 | 国产三级日本三级在线播放 | 精品一区二区三区免费毛片爱 | 成年人网站免费视频 |