1、一條簡單的sql語句底層的執行過程是怎么樣的?
答:一條sql執行會經過連接器、查詢緩存、分析器、優化器和執行器等步驟。
2、連接器的作用是什么?
答:sql查詢,首先連接到這個數據庫上,這時候接待你的就是連接器。連接器負責跟客戶端建立連接、獲取權限、維持和管理連接。連接命令一般是這么寫的:MySQL -h$ip -P$port -u$user -p,然后輸入密碼。
3、連接器建立連接之后,一直不操作,它會自動斷開嗎?
答:客戶端如果太長時間沒動靜,連接器就會自動將它斷開。這個時間是由參數wait_timeout控制的,默認值是8小時。
如果在連接被斷開之后,客戶端再次發送請求的話,就會收到一個錯誤提醒: Lost connection to MySQL server during query。這時候如果你要繼續,就需要重連,然后再執行請求了。
數據庫里面,長連接是指連接成功后,如果客戶端持續有請求,則一直使用同一個連接。短連接則是指每次執行完很少的幾次查詢就斷開連接,下次查詢再重新建立一個。
建立連接的過程通常是比較復雜的,所以我建議你在使用中要盡量減少建立連接的動作,也就是盡量使用長連接。
但是全部使用長連接后,你可能會發現,有些時候MySQL占用內存漲得特別快,這是因為MySQL在執行過程中臨時使用的內存是管理在連接對象里面的。這些資源會在連接斷開的時候才釋放。所以如果長連接累積下來,可能導致內存占用太大,被系統強行殺掉(OOM),從現象看就是MySQL異常重啟了。
怎么解決這個問題呢?你可以考慮以下兩種方案。
定期斷開長連接。使用一段時間,或者程序里面判斷執行過一個占用內存的大查詢后,斷開連接,之后要查詢再重連。
如果你用的是MySQL 5.7或更新版本,可以在每次執行一個比較大的操作后,通過執行 mysql_reset_connection來重新初始化連接資源。這個過程不需要重連和重新做權限驗證,但是會將連接恢復到剛剛創建完時的狀態。
4.查詢緩存流程?
答:建立連接后,然后接著會查詢緩存,緩存中存儲是key-value形式存儲,key是查詢語句,value是查詢結果,查詢到直接返回,沒有查詢到會查詢數據庫。
但是大多數情況下我會建議你不要使用查詢緩存,為什么呢?因為查詢緩存往往弊大于利。
查詢緩存的失效非常頻繁,只要有對一個表的更新,這個表上所有的查詢緩存都會被清空。
除非你的業務就是有一張靜態表,很長時間才會更新一次。比如,一個系統配置表,那這張表上的查詢才適合使用查詢緩存。
好在MySQL也提供了這種“按需使用”的方式。你可以將參數query_cache_type設置成DEMAND,這樣對于默認的SQL語句都不使用查詢緩存。而對于你確定要使用查詢緩存的語句,可以用SQL_CACHE顯式指定,像下面這個語句一樣:
mysql> select SQL_CACHE * from T where ID=10;
需要注意的是,MySQL 8.0版本直接將查詢緩存的整塊功能刪掉了,也就是說8.0開始徹底沒有這個功能了。
5.分析器的作用?
答:分析器主要對sql語句進行詞法分析和語法分析。
詞法分析主要會分析一條sql語句中的字符串代表什么,語法分析sql語句是否符合mysql語法規范。
6.優化器的作用?
答:優化器是在表里面有多個索引的時候,決定使用哪個索引;或者在一個語句有多表關聯(join)的時候,決定各個表的連接順序。
7、執行器作用?
答:開始執行的時候,要先判斷一下你對這個表T有沒有執行查詢的權限,如果沒有,就會返回沒有權限的錯誤。如果有權限,就打開表繼續執行。打開表的時候,執行器就會根據表的引擎定義,去使用這個引擎提供的接口。
select * from teacher where id =10
調用InnoDB引擎接口取這個表的第一行,判斷ID值是不是10,如果不是則跳過,如果是則將這行存在結果集中;
調用引擎接口取“下一行”,重復相同的判斷邏輯,直到取到這個表的最后一行。
執行器將上述遍歷過程中所有滿足條件的行組成的記錄集作為結果集返回給客戶端。
————————————————
版權聲明:本文為CSDN博主「TingWang7916」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.NET/weixin_42289193/article/details/128053581