主頁(yè) > 知識(shí)庫(kù) > 論一條select語(yǔ)句在MySQL是怎樣執(zhí)行的

論一條select語(yǔ)句在MySQL是怎樣執(zhí)行的

熱門(mén)標(biāo)簽:400電話(huà)可以辦理嗎 云南電商智能外呼系統(tǒng)價(jià)格 拉卡拉外呼系統(tǒng) 臨清電話(huà)機(jī)器人 大眾點(diǎn)評(píng)星級(jí)酒店地圖標(biāo)注 話(huà)務(wù)外呼系統(tǒng)怎么樣 高清地圖標(biāo)注道路 外東北地圖標(biāo)注 智能外呼系統(tǒng)復(fù)位

一、從宏觀的角度分析MySQL

首先看一張經(jīng)典圖片(MySQL邏輯架構(gòu)圖

上圖的客戶(hù)端可以直接理解為PHP、Java等。接下來(lái),你會(huì)看到連接、線(xiàn)程處理。這一部分并不是MySQL所特有的,而且大多數(shù)客戶(hù)端、服務(wù)器都具有類(lèi)似的結(jié)構(gòu)。

因此,一般而言,MySQL可以分為兩層:Server層和存儲(chǔ)引擎層。

Server層主要包括連接層、查詢(xún)緩存、分析器、優(yōu)化器、執(zhí)行器等重要模塊組成,這一層還包含了MySQL核心Api部分,比如常用的格式化時(shí)間、加密等。

存儲(chǔ)引擎大家都很熟悉,因?yàn)樵诿嬖囍胁恢挂淮蔚膯?wèn)過(guò)大家Innodb、Myisam存儲(chǔ)引擎的不同。

所以想過(guò)沒(méi)有,MySQL為什么會(huì)有這么多的存儲(chǔ)引擎呢?

一切技術(shù)起源于當(dāng)下問(wèn)題,同樣在MySQL中也不例外。

MySQL在存儲(chǔ)引擎這一方面的架構(gòu)是插件式的,即可以隨意切換不固定,而且MySQL5.5版本存儲(chǔ)引擎已經(jīng)默認(rèn)為Innodb。

二、一條SQL執(zhí)行要經(jīng)過(guò)多少困難?

MySQL詳細(xì)架構(gòu)圖

圖中還有一個(gè)熟悉的陌生人查詢(xún)緩存模塊,該模塊在MySQL8.0中已不存在。

首先,我們將大致了解當(dāng)我們執(zhí)行一條SQL語(yǔ)句時(shí),如何在這個(gè)架構(gòu)圖中運(yùn)行。

2-1 連接器

mysql -u root -p連接數(shù)據(jù)庫(kù)命令,在執(zhí)行之后,你將需要輸入密碼。當(dāng)完成經(jīng)典的TCP握手之后,連接器就開(kāi)始發(fā)揮作用了。

如果碼錯(cuò)誤時(shí),則返回Access denied for user ‘root‘@‘localhost‘ (using password: YES,錯(cuò)誤編碼1045。

如果連接信息均正確,則此時(shí)將根據(jù)你輸入的用戶(hù)訪(fǎng)問(wèn)權(quán)限表來(lái)獲取該用戶(hù)的權(quán)限,此處必須清楚,當(dāng)你登錄成功后,即使其他人修改了你的權(quán)限,在這個(gè)連接未斷開(kāi)之前你的權(quán)限是不會(huì)發(fā)生改變的。

當(dāng)你連接完成之后,如果你一直不做任何事情,執(zhí)行show processlist將會(huì)看到一個(gè)sleep,表示空連接。

那么你知道在MySQL中,如果連接成功后沒(méi)有進(jìn)行任何操作,多久會(huì)被自動(dòng)中斷?

可以執(zhí)行show variables like 'wait_timeout';用于查看時(shí)間。

在MySQL中如果沒(méi)有特別說(shuō)明,那么所有的時(shí)間都是以秒為單位的,根據(jù)時(shí)間轉(zhuǎn)換可以得知空連接持續(xù)8小時(shí)。

2-2 查詢(xún)緩存

你需要注意的是,MySQL8.0已經(jīng)被取消了,這個(gè)問(wèn)題不止說(shuō)了一次了,特別是那些正在使用MySQL8.0以下版本的小伙伴要注意哈!當(dāng)你切換到8.0時(shí)候,遇到這個(gè)問(wèn)題不知道怎么解決。

MySQL8.0為何取消查詢(xún)緩存模塊

這個(gè)模塊的設(shè)計(jì),把查詢(xún)語(yǔ)句作為key ,將結(jié)果作為value 進(jìn)行緩存,一旦這個(gè)表有更新,之前所有的緩存都會(huì)被清除掉。這就像你辛辛苦苦寫(xiě)的代碼提交之后被別人覆蓋一樣難受。

MySQL8.0以下的版本提供了一個(gè)參數(shù)query_cache_type = enmand來(lái)控制是否要使用查詢(xún)緩存,在設(shè)置完成后,默認(rèn)的select語(yǔ)句將不會(huì)被緩存。

如果確實(shí)可以使用部分場(chǎng)景,那么你可以將sql_cache添加到select關(guān)鍵字之后。

如果一條select語(yǔ)句之前被緩存過(guò),那么結(jié)果集在這里就會(huì)直接返回,而沒(méi)有緩存過(guò)的select語(yǔ)句就比較辛苦了,還要繼續(xù)自己的漫漫長(zhǎng)路。

2-3 分析器

MySQL8.0之前,它會(huì)在進(jìn)入分析器之前判斷是否緩存,在MySQL8.0之后,連接器驗(yàn)證成功后就直接進(jìn)入分析器。

分析器,根據(jù)字面意思來(lái)理解就是分析要執(zhí)行的SQL語(yǔ)句是什么,要做什么。

比如執(zhí)行select * from user where id = 1

MySQL首先根據(jù)select判斷這是一個(gè)查詢(xún)語(yǔ)句,然后將user識(shí)別為表名,id識(shí)別為字段名,這個(gè)過(guò)程被稱(chēng)為詞法分析。

下一步,需要知道該SQL的語(yǔ)法是否正確,進(jìn)行語(yǔ)法分析,如果語(yǔ)法不對(duì)你就會(huì)看到Y(jié)ou have an error in your SQL syntax錯(cuò)誤。通常,將在use near中找到該錯(cuò)誤。

2-4 優(yōu)化器

到了這一步,MySQL知道你要做什么,但是要選擇最佳執(zhí)行方案。

優(yōu)化器都優(yōu)化些什么?

舉例來(lái)說(shuō):多個(gè)索引時(shí)選擇那個(gè)索引、多表關(guān)聯(lián)時(shí)連接順序。

現(xiàn)在你是否想知道,優(yōu)化器將優(yōu)化多表關(guān)聯(lián)的連接順序,那在寫(xiě)SQL語(yǔ)句時(shí)是否就不必考慮連接順序呢?

當(dāng)然不是,能讓MySQL少做事情就少做,還是一個(gè)準(zhǔn)則用小表驅(qū)動(dòng)大表。

2-5 執(zhí)行器

通過(guò)要做什么、怎么做后這條SQL語(yǔ)句才會(huì)真正的被執(zhí)行,先進(jìn)行權(quán)限驗(yàn)證,若沒(méi)有權(quán)限則直接返回權(quán)限錯(cuò)誤,否則根據(jù)表定義的存儲(chǔ)引擎,去使用對(duì)應(yīng)引擎提供的接口。

執(zhí)行流程圖

上圖包含了正文的所有知識(shí)點(diǎn),也是整個(gè)MySQL的大體執(zhí)行流程圖。

到此這篇關(guān)于論一條select語(yǔ)句在MySQL是怎樣執(zhí)行的的文章就介紹到這了,更多相關(guān)select執(zhí)行MySQL語(yǔ)句內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python基礎(chǔ)之python循環(huán)控制語(yǔ)句break/continue詳解
  • C語(yǔ)言之初始if語(yǔ)句詳解
  • C語(yǔ)言入門(mén)篇--學(xué)習(xí)選擇,if,switch語(yǔ)句以及代碼塊
  • 如何用c++表驅(qū)動(dòng)替換if/else和switch/case語(yǔ)句
  • C語(yǔ)言中常見(jiàn)的幾種流程控制語(yǔ)句
  • 一篇文章帶你了解JavaScript-語(yǔ)句
  • Python實(shí)現(xiàn)switch/case語(yǔ)句
  • C語(yǔ)言進(jìn)階教程之循環(huán)語(yǔ)句缺陷詳析
  • C語(yǔ)言控制語(yǔ)句之 循環(huán)
  • mybatis中sql語(yǔ)句CDATA標(biāo)簽的用法說(shuō)明
  • JavaScript中三種for循環(huán)語(yǔ)句的使用總結(jié)(for、for...in、for...of)
  • golang switch語(yǔ)句的靈活寫(xiě)法介紹
  • C 語(yǔ)言基礎(chǔ)之C 語(yǔ)言三大語(yǔ)句注意事項(xiàng)

標(biāo)簽:三明 福州 溫州 揚(yáng)州 無(wú)錫 定西 山西 阿里

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《論一條select語(yǔ)句在MySQL是怎樣執(zhí)行的》,本文關(guān)鍵詞  論,一條,select,語(yǔ)句,在,MySQL,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《論一條select語(yǔ)句在MySQL是怎樣執(zhí)行的》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于論一條select語(yǔ)句在MySQL是怎樣執(zhí)行的的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章