成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > 新手入門Mysql--sql執(zhí)行過程

新手入門Mysql--sql執(zhí)行過程

熱門標簽:大眾點評星級酒店地圖標注 外東北地圖標注 智能外呼系統(tǒng)復位 高清地圖標注道路 臨清電話機器人 拉卡拉外呼系統(tǒng) 400電話可以辦理嗎 話務外呼系統(tǒng)怎么樣 云南電商智能外呼系統(tǒng)價格

1. 流程

2. 核心架構

簡單來說 MySQL 主要分為 Server 層和存儲引擎層:

  • Server 層:主要包括連接器、查詢緩存、分析器、優(yōu)化器、執(zhí)行器等,所有跨存儲引擎的功能都在這一層實現,比如存儲過程、觸發(fā)器、視圖,函數等,還有一個通用的日志模塊 binglog 日志模塊。
  • 存儲引擎: 主要負責數據的存儲和讀取,采用可以替換的插件式架構,支持 InnoDB、MyISAM、Memory 等多個存儲引擎,其中 InnoDB 引擎有自有的日志模塊 redolog 模塊?,F在最常用的存儲引擎是 InnoDB,它從 MySQL 5.5.5 版本開始就被當做默認存儲引擎了。

 2.1 Server 層基本組件介紹

1.連接器

連接器主要和身份認證和權限相關的功能相關,就好比一個級別很高的門衛(wèi)一樣。

主要負責用戶登錄數據庫,進行用戶的身份認證,包括校驗賬戶密碼,權限等操作,如果用戶賬戶密碼已通過,連接器會到權限表中查詢該用戶的所有權限,之后在這個連接里的權限邏輯判斷都是會依賴此時讀取到的權限數據,也就是說,后續(xù)只要這個連接不斷開,即時管理員修改了該用戶的權限,該用戶也是不受影響的。

2.查詢緩存(MySQL 8.0 版本后移除)

查詢緩存主要用來緩存我們所執(zhí)行的 SELECT 語句以及該語句的結果集。

連接建立后,執(zhí)行查詢語句的時候,會先查詢緩存,MySQL 會先校驗這個 sql 是否執(zhí)行過,以 Key-Value 的形式緩存在內存中,Key 是查詢預計,Value 是結果集。如果緩存 key 被命中,就會直接返回給客戶端,如果沒有命中,就會執(zhí)行后續(xù)的操作,完成后也會把結果緩存起來,方便下一次調用。當然在真正執(zhí)行緩存查詢的時候還是會校驗用戶的權限,是否有該表的查詢條件。

MySQL 查詢不建議使用緩存,因為查詢緩存失效在實際業(yè)務場景中可能會非常頻繁,假如你對一個表更新的話,這個表上的所有的查詢緩存都會被清空。對于不經常更新的數據來說,使用緩存還是可以的。

所以,一般在大多數情況下我們都是不推薦去使用查詢緩存的。

MySQL 8.0 版本后刪除了緩存的功能,官方也是認為該功能在實際的應用場景比較少,所以干脆直接刪掉了。

3.分析器

MySQL 沒有命中緩存,那么就會進入分析器,分析器主要是用來分析 SQL 語句是來干嘛的,分析器也會分為幾步:

  1. 第一步,詞法分析,一條 SQL 語句有多個字符串組成,首先要提取關鍵字,比如 select,提出查詢的表,提出字段名,提出查詢條件等等。做完這些操作后,就會進入第二步。
  2. 第二步,語法分析,主要就是判斷你輸入的 sql 是否正確,是否符合 MySQL 的語法。

完成這 2 步之后,MySQL 就準備開始執(zhí)行了,但是如何執(zhí)行,怎么執(zhí)行是最好的結果呢?這個時候就需要優(yōu)化器上場了。

4.優(yōu)化器

優(yōu)化器的作用就是它認為的最優(yōu)的執(zhí)行方案去執(zhí)行(有時候可能也不是最優(yōu),這篇文章涉及對這部分知識的深入講解),比如多個索引的時候該如何選擇索引,多表查詢的時候如何選擇關聯順序等。

可以說,經過了優(yōu)化器之后可以說這個語句具體該如何執(zhí)行就已經定下來。

5.執(zhí)行器

當選擇了執(zhí)行方案后,MySQL 就準備開始執(zhí)行了,首先執(zhí)行前會校驗該用戶有沒有權限,如果沒有權限,就會返回錯誤信息,如果有權限,就會去調用引擎的接口,返回接口執(zhí)行的結果。

3. 語句分析

3.1 查詢語句

sql 可以分為兩種,一種是查詢,一種是更新(增加,更新,刪除)。我們先分析下查詢語句,語句如下:

select * from tb_student A where A.age=‘18' and A.name=' 張三 ';

結合上面的說明,我們分析下這個語句的執(zhí)行流程:

先檢查該語句是否有權限,如果沒有權限,直接返回錯誤信息,如果有權限,在 MySQL8.0 版本以前,會先查詢緩存,以這條 sql 語句為 key 在內存中查詢是否有結果,如果有直接緩存,如果沒有,執(zhí)行下一步。

通過分析器進行詞法分析,提取 sql 語句的關鍵元素,比如提取上面這個語句是查詢 select,提取需要查詢的表名為 tb_student,需要查詢所有的列,查詢條件是這個表的 id=‘1'。然后判斷這個 sql 語句是否有語法錯誤,比如關鍵詞是否正確等等,如果檢查沒問題就執(zhí)行下一步。

接下來就是優(yōu)化器進行確定執(zhí)行方案,上面的 sql 語句,可以有兩種執(zhí)行方案:

a. 先查詢學生表中姓名為“張三”的學生,然后判斷是否年齡是 18。
b. 先找出學生中年齡 18 歲的學生,然后再查詢姓名為“張三”的學生。

那么優(yōu)化器根據自己的優(yōu)化算法進行選擇執(zhí)行效率最好的一個方案(優(yōu)化器認為,有時候不一定最好)。那么確認了執(zhí)行計劃后就準備開始執(zhí)行了。

進行權限校驗,如果沒有權限就會返回錯誤信息,如果有權限就會調用數據庫引擎接口,返回引擎的執(zhí)行結果。

3.2 更新語句

以上就是一條查詢 sql 的執(zhí)行流程,那么接下來我們看看一條更新語句如何執(zhí)行的呢?sql 語句如下:

update tb_student A set A.age=‘19' where A.name=' 張三 ';

我們來給張三修改下年齡,在實際數據庫肯定不會設置年齡這個字段的,不然要被技術負責人打的。其實條語句也基本上會沿著上一個查詢的流程走,只不過執(zhí)行更新的時候肯定要記錄日志啦,這就會引入日志模塊了,MySQL 自帶的日志模塊式 binlog(歸檔日志) ,所有的存儲引擎都可以使用,我們常用的 InnoDB 引擎還自帶了一個日志模塊 redo log(重做日志),我們就以 InnoDB 模式下來探討這個語句的執(zhí)行流程。流程如下:

先查詢到張三這一條數據,如果有緩存,也是會用到緩存。

然后拿到查詢的語句,把 age 改為 19,然后調用引擎 API 接口,寫入這一行數據,InnoDB 引擎把數據保存在內存中,同時記錄 redo log,此時 redo log 進入 prepare 狀態(tài),然后告訴執(zhí)行器,執(zhí)行完成了,隨時可以提交。

執(zhí)行器收到通知后記錄 binlog,然后調用引擎接口,提交 redo log 為提交狀態(tài)。

更新完成。

這里肯定有同學會問,為什么要用兩個日志模塊,用一個日志模塊不行嗎?

這是因為最開始 MySQL 并沒與 InnoDB 引擎( InnoDB 引擎是其他公司以插件形式插入 MySQL 的) ,MySQL 自帶的引擎是 MyISAM,但是我們知道 redo log 是 InnoDB 引擎特有的,其他存儲引擎都沒有,這就導致會沒有 crash-safe 的能力(crash-safe 的能力即使數據庫發(fā)生異常重啟,之前提交的記錄都不會丟失),binlog 日志只能用來歸檔。

并不是說只用一個日志模塊不可以,只是 InnoDB 引擎就是通過 redo log 來支持事務的。那么,又會有同學問,我用兩個日志模塊,但是不要這么復雜行不行,為什么 redo log 要引入 prepare 預提交狀態(tài)?這里我們用反證法來說明下為什么要這么做?

先寫 redo log 直接提交,然后寫 binlog,假設寫完 redo log 后,機器掛了,binlog 日志沒有被寫入,那么機器重啟后,這臺機器會通過 redo log 恢復數據,但是這個時候 bingog 并沒有記錄該數據,后續(xù)進行機器備份的時候,就會丟失這一條數據,同時主從同步也會丟失這一條數據。

先寫 binlog,然后寫 redo log,假設寫完了 binlog,機器異常重啟了,由于沒有 redo log,本機是無法恢復這一條記錄的,但是 binlog 又有記錄,那么和上面同樣的道理,就會產生數據不一致的情況。

如果采用 redo log 兩階段提交的方式就不一樣了,寫完 binglog 后,然后再提交 redo log 就會防止出現上述的問題,從而保證了數據的一致性。那么問題來了,有沒有一個極端的情況呢?假設 redo log 處于預提交狀態(tài),binglog 也已經寫完了,這個時候發(fā)生了異常重啟會怎么樣呢? 這個就要依賴于 MySQL 的處理機制了,MySQL 的處理過程如下:

判斷 redo log 是否完整,如果判斷是完整的,就立即提交。

如果 redo log 只是預提交但不是 commit 狀態(tài),這個時候就會去判斷 binlog 是否完整,如果完整就提交 redo log, 不完整就回滾事務。

這樣就解決了數據一致性的問題。

4. 總結

  • MySQL 主要分為 Server 層和引擎層,Server 層主要包括連接器、查詢緩存、分析器、優(yōu)化器、執(zhí)行器,同時還有一個日志模塊(binlog),這個日志模塊所有執(zhí)行引擎都可以共用,redolog 只有 InnoDB 有。
  • 引擎層是插件式的,目前主要包括,MyISAM,InnoDB,Memory 等。
  • SQL 等執(zhí)行過程分為兩類,一類對于查詢等過程如下:權限校驗—》查詢緩存—》分析器—》優(yōu)化器—》權限校驗—》執(zhí)行器—》引擎
  • 對于更新等語句執(zhí)行流程如下:分析器----》權限校驗----》執(zhí)行器—》引擎—redo log prepare—》binlog—》redo log commit

這篇文章就到這了,希望大家可以多多關注腳本之家的其他內容!

您可能感興趣的文章:
  • MySql新手入門的基本操作匯總
  • MySQL新手入門指南--快速參考
  • 新手入門Mysql--概念

標簽:揚州 阿里 定西 三明 福州 溫州 無錫 山西

巨人網絡通訊聲明:本文標題《新手入門Mysql--sql執(zhí)行過程》,本文關鍵詞  新手入門,Mysql--sql,執(zhí)行,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《新手入門Mysql--sql執(zhí)行過程》相關的同類信息!
  • 本頁收集關于新手入門Mysql--sql執(zhí)行過程的相關信息資訊供網民參考!
  • 推薦文章
    日韩人妻无码一区二区三区99| 亚洲欧美综合图片| 2021年精品国产福利在线| 天天添天天操| 亚洲精品国产偷自在线观看| 另类专区欧美| 精品日韩在线一区| 亚洲天堂视频在线播放| 国产精品无av码在线观看| 欧美日韩激情视频一区二区三区| 91传媒视频在线观看| 日韩中文字幕在线视频播放| 国产日韩欧美精品电影三级在线| 国产精品免费在线播放| 91视频免费在线观看| 高清电影在线观看免费| 青草视频在线观看免费| 欧美日韩精品久久久免费观看| 最近中文字幕大全中文字幕免费| 成人黄色网址在线观看| 久久av网址| 青春草国产成人精品久久| 正在播放一区二区| 亚洲欧美在线免费观看| 成人免费视频国产免费| yellow网站在线观看| 91人成网站www| 精品亚洲一区二区| 欧美mv日韩mv国产网站app| 国产一区二区三区免费播放| 婷婷激情5月天| 18岁视频在线观看| 欧美在线观看天堂一区二区三区| 中日韩av在线播放| 欧洲午夜精品| 午夜激情影院| 一区二区三区在线免费看| 亚洲自拍欧美精品| 美日韩丰满少妇在线观看| 中文字幕国产亚洲| 91精品国自产在线偷拍蜜桃| 国产国语老龄妇女a片| 日韩精品免费一区二区三区| 国产精品热视频| 少妇视频一区二区| 51国产成人精品午夜福中文下载| 亚洲国产日韩一区无码精品久久久| 日韩一级大片在线观看| 日韩免费电影网站| 国产精品少妇自拍| 国产a√精品区二区三区四区| 在线观看中文字幕网站| 少妇特黄a一区二区三区| 一级黄色大片视频| 国产成人在线综合| 国产精品麻豆免费版现看视频| 国产精品视频一二三区| 国产一区二区三区黄网站| 午夜两性免费视频| 四虎一区二区| 精品污污网站免费看| 精品一区二区在线播放| 日韩欧美中文免费| 久操免费在线视频| 日韩在线播放一区二区| 日韩不卡一区二区三区| 香蕉污视频在线观看| 欧美aaa视频| 久久青草伊人| 成人午夜两性视频| 清纯唯美亚洲综合一区| 成人国内精品久久久久一区| 国产女人水真多18毛片18精品视频| 无码人妻久久一区二区三区蜜桃| 91亚洲精品久久久蜜桃| 明星乱亚洲合成图.com| 视频免费在线看| hitomi一区二区三区精品| 天海翼精品一区二区三区| 99免在线观看免费视频高清| 黄色免费网站视频| 99精品视频在线播放免费| 九色丨porny丨自拍入口| 日韩av高清在线看片| 国产精品美女久久久久久久久久久| 日本一二三区在线| 人成网站在线观看| 97色在线观看| 成人在线高清视频| 日韩国产高清在线| 国产乱人伦偷精品视频免下载| 久久精品凹凸全集| 爱情岛亚洲播放路线| 亚洲天天做日日做天天谢日日欢| 久久久久久久影院| 日韩欧美一级特黄在线播放| 激情欧美一区二区三区| 日本精品久久久久久| aaa一区二区| 久久久免费网站| 777午夜精品视频在线播放| 91日韩视频在线观看| 91社影院在线观看| 亚洲欧美日韩综合精品网| 欧美成人高清电影在线| 亚洲av无码成人精品国产| 最近中文字幕2019第二页视频| 一本一道久久a久久精品蜜桃| 亚洲不卡视频在线观看| 欧美日韩成人综合天天影院| 无码无遮挡又大又爽又黄的视频| 日本理论片午伦夜理片在线观看| 26uuu色噜噜精品一区二区| 欧美影院一区二区| 91年精品国产| 中文字幕亚洲二区| 91精品综合久久久久久五月天| 日韩高清不卡一区二区| 国产aⅴ精品一区二区三区黄| 自拍偷拍在线视频| 岛国视频免费在线观看| 操日韩av在线电影| 国产在线色视频| 精品一区久久久| 久草在线免费资源站| 韩国中文字幕hd久久精品| 欧美黑人ⅹxxx另类猛交| 美女又爽又黄免费动漫| 中文子幕无线码一区tr| 曰韩少妇与小伙激情| 国产a级黄色大片| 久久综合久久美利坚合众国| 国产精品入口麻豆完整版| 精品美女一区| 天天做夜夜爱爱爱| 国产福利在线免费| 国产精品极品尤物在线观看| 天天天干夜夜夜操| eeuss影院130020部| 日韩av字幕| 欧美一级一区| 美女精品视频在线| 久久综合亚洲色hezyo国产| 日韩经典一区二区| 少妇熟女一区二区| 国产精品午夜电影| 久久福利资源站| 无码国产精品一区二区色情男同| 精品99久久| 久久综合九色综合97_久久久| 成人欧美一区二区三区在线| 美女日韩在线中文字幕| 久久久成人精品视频| 欧美国产一区在线| 日本黄色三级视频| 日本在线不卡视频一二三区| 亚洲不卡av不卡一区二区| 中文字幕在线观看免费高清| 国产成人精品免费看视频| 欧美一级一区二区三区| 中文字幕剧情在线观看| 爱爱视频网站| 深夜成人在线观看| 日韩少妇视频| 先锋影音欧美性受| 亚洲欧美日韩中文视频| 成人免费短视频| 五十路熟女丰满大屁股| 亚洲日本中文| 久久99精品网久久| 在线天堂资源www在线污| 国产在线精品一区免费香蕉| 欧美日韩国产精品一区二区三区| 亚洲成年人在线观看| 丝袜美腿一区二区三区| 日韩欧美一区二区三区久久婷婷| 欧美成人直播| 蜜臀久久精品久久久久| 精品久久久久久中文字幕大豆网| 人人妻人人藻人人爽欧美一区| 黄网站免费久久| 99精品视频一区二区| 久久青青视频| 成人深夜直播免费观看| 亚洲激情在线观看| 欧美成人69av| 亚洲人成五月天| 国产奶头好大揉着好爽视频| 中文字幕在线一| 性8sex亚洲区入口| 亚洲free性xxxx护士hd| 欧美午夜精品一区二区| 四季av综合网站| 亚洲va欧美va国产综合剧情| av中文字幕在线看| 久草中文在线视频| 国产精品国产三级国产aⅴ浪潮| 欧美极品xxxx| 亚洲欧美国产精品久久久久久久| 美女爆乳18禁www久久久久久| 日韩久久久久久久久久久| 免费av播放| 久久人妻精品白浆国产| 亚洲国产成人一区二区| 日韩中文字幕亚洲| www.豆豆成人网.com| 欧美特黄一级| 欧美精品aa| 亚洲蜜桃精久久久久久久| 国产一级网站视频在线| 欧美一级淫片aaaaaa| 欧美最猛黑人xxxxwww| f2c人成在线观看免费视频| 国产丝袜视频在线观看| 国产精品综合网站| 亚洲精品乱码久久久久久蜜桃欧美| 久久久精品日韩欧美| 亚洲自拍偷拍一区| 天堂社区在线视频| 九九九免费视频| 亚洲欧美一级二级三级| 中文字幕在线亚洲精品| 2020最新国产精品| 国产精品久久久久久久久| 69av在线视频| 污污的网站在线免费观看| 国产精品第6页| 在线综合视频网站| 美女在线免费视频| 一区二区三区欧美成人| 亚洲欧洲中文日韩久久av乱码| 日韩电影不卡一区| 中日韩黄色大片| 久久免费精品国产| 制服.丝袜.亚洲.中文.综合懂色| 国产精品视频500部| 猛男欧美办公室激情在线| www.久久色| 亚洲男女视频在线观看| 在线中文字日产幕| 国产传媒欧美日韩成人| 先锋在线资源一区二区三区| 欧美日韩国产一区二区在线观看| 亚洲一区精品视频| 国产伦精品一区二区三区免费优势| 成人区一区二区| 欧美国产日本高清在线| 成人福利视频在线| 黑人巨大精品欧美一区二区三区| 欧美 日韩 国产 在线观看| av电影在线观看一区二区三区| 欧美黄色一级网站| 亚洲国产精品久久久久婷蜜芽| 中文字幕一区二区在线观看| 丝袜诱惑制服诱惑色一区在线观看| 日韩伦理在线视频| 国产一区二区在线播放| 啦啦啦啦免费高清视频在线观看1| 国产91免费观看| 国产成人精品免费看在线播放| 亚洲你懂的在线视频| 久久久91麻豆精品国产一区| 欧美激情一区二区三区成人| 成人xxx免费视频播放| 99在线|亚洲一区二区| 日日夜夜精品视频天天综合网| 最近中文字幕mv第三季歌词| 欧美电影在线观看完整版| 国产精品边吃奶边做爽| 一区二区三区日韩在线| 亚洲欧美日韩在线观看a三区| 韩国精品主播一区二区在线观看| 四虎国产精品免费久久| 中文字幕亚洲综合久久五月天色无吗''| 91嫩草免费看| av黄色在线看| 久久er99热精品一区二区三区| 裸体xxxx视频在线| 人人妻人人澡人人爽人人精品| 四虎影视免费看电影| 自拍电影在线观看| 欧美猛男超大videosgay| 精品av久久707| 国产精品999视频| 美女脱光内衣内裤视频久久影院| 蜜桃av导航| 欧美日韩精品国产| 日韩不卡在线观看| 国产欧美日韩综合一区在线播放| 欧美亚洲图片小说| 向日葵视频成人app网址| 蜜乳av综合| 白白色亚洲国产精品| 国模私拍在线观看| 99视频在线精品国自产拍免费观看| 亚洲国产精品无码久久久| 亚洲精品成人区在线观看| 欧美日韩国产美| 亚洲国产精品综合久久久| 日韩久久精品一区| 国产综合色视频| 97超碰色婷婷| 亚洲国产精品嫩草影院| 91在线网址| 免费看污片的软件| 国产精品中文久久久久久| 国产美女在线播放| 欧美色视频一区二区三区在线观看| 2020久久国产精品| 天堂电影一区| 精品国偷自产国产一区| jizz亚洲| 韩国av永久免费| 成 人免费视频播放| 亚洲天堂免费| 女同一区二区免费aⅴ| 亚洲精品日本| av在线亚洲一区| 正在播放久久| 欧美高跟鞋交xxxxhd| 日本精品久久久久久久久久| 69xxx免费视频| 一区二区不卡久久精品| 亚洲欧美精品一区二区三区| 欧美日溪乱毛片| freehdxxxx| 欧美精品一区二区久久| 天天碰免费视频|