婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

新手入門Mysql--sql執行過程

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

1. 流程

2. 核心架構

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

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

 2.1 Server 層基本組件介紹

1.連接器

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

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

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

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

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

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

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

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

3.分析器

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

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

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

4.優化器

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

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

5.執行器

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

3. 語句分析

3.1 查詢語句

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

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

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

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

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

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

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

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

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

3.2 更新語句

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

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

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

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

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

執行器收到通知后記錄 binlog,然后調用引擎接口,提交 redo log 為提交狀態。

更新完成。

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

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

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

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

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

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

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

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

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

4. 總結

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

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

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

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

巨人網絡通訊聲明:本文標題《新手入門Mysql--sql執行過程》,本文關鍵詞  新手入門,Mysql--sql,執行,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《新手入門Mysql--sql執行過程》相關的同類信息!
  • 本頁收集關于新手入門Mysql--sql執行過程的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日本一区二区电影| 亚洲日本一区二区| 亚洲午夜一区二区三区| 不卡的av在线| www.亚洲国产| 亚洲视频你懂的| 国产成a人亚洲精品| k8久久久一区二区三区| 中文字幕一区二区视频| 成人欧美一区二区三区黑人麻豆| 国产一区二区三区免费看| 亚洲午夜视频在线观看| xvideos.蜜桃一区二区| 日韩欧美在线123| 精品国偷自产国产一区| 日韩激情一二三区| 中文字幕一区免费在线观看| 亚洲啪啪综合av一区二区三区| 亚洲国产成人tv| 国产一区二区视频在线| 亚洲一区影音先锋| 日韩欧美色综合网站| 欧美精品一卡二卡| 欧美三级日韩在线| 精品免费国产一区二区三区四区| 琪琪一区二区三区| 国产精品拍天天在线| 911国产精品| 精品国产91洋老外米糕| 国产成人一区在线| 91免费看片在线观看| 国产成人综合精品三级| 国产福利91精品一区二区三区| 亚洲成人av电影| 国产一区二区在线看| 成人久久视频在线观看| 亚洲精品一区二区三区在线观看| 亚洲欧洲av在线| 国产欧美视频一区二区三区| 亚洲视频资源在线| 国产一区二区三区久久久| 国产乱人伦偷精品视频免下载| 色噜噜狠狠色综合中国| 欧美调教femdomvk| 亚洲欧美一区二区久久| 国产91综合一区在线观看| 日本二三区不卡| 亚洲日本成人在线观看| 九一九一国产精品| 成人免费三级在线| 久久精品一级爱片| 欧美精品一区男女天堂| 性久久久久久久| 欧美三级视频在线播放| 免费看欧美女人艹b| 欧美三级电影精品| 裸体一区二区三区| 91色视频在线| 日韩精品一区在线观看| 日韩精品午夜视频| 欧美日韩国产精品自在自线| 亚洲欧美国产三级| 色老综合老女人久久久| 久久99久久99| 日韩欧美一区电影| 国模少妇一区二区三区| 亚洲欧美aⅴ...| 91精品国产入口| eeuss鲁一区二区三区| 亚洲国产裸拍裸体视频在线观看乱了 | 精品在线免费视频| 91香蕉视频在线| 一个色综合网站| 精品乱码亚洲一区二区不卡| 成人av午夜电影| 日本午夜一区二区| 国产午夜亚洲精品不卡| 中文字幕精品一区| 亚洲尤物视频在线| heyzo一本久久综合| 日本不卡视频在线| 久久综合99re88久久爱| 欧美性大战久久久久久久蜜臀| 久久国产福利国产秒拍| 亚洲精品日产精品乱码不卡| 欧美刺激午夜性久久久久久久| 成人av中文字幕| 午夜精品久久久久| 亚洲三级免费电影| 欧美浪妇xxxx高跟鞋交| 粉嫩一区二区三区性色av| 亚洲精品国产无套在线观| 亚洲视频一二三| 国产欧美一区二区三区在线看蜜臀 | 国产精品不卡一区二区三区| 成人免费毛片aaaaa**| 天堂久久一区二区三区| 天堂久久久久va久久久久| 亚洲精品v日韩精品| 日韩欧美色电影| 成人网在线免费视频| 亚洲国产精品一区二区久久| 91精品福利在线| 99精品欧美一区二区三区综合在线| 性感美女极品91精品| 自拍偷拍亚洲欧美日韩| 国产黑丝在线一区二区三区| 国产精品福利av| 韩国成人精品a∨在线观看| 欧美日韩国产不卡| 国产99久久久精品| 久久精品噜噜噜成人88aⅴ| 欧美日韩aaa| 奇米精品一区二区三区在线观看 | 精品电影一区二区三区| 99久久国产综合精品色伊| 欧美高清视频www夜色资源网| 欧美日韩极品在线观看一区| 99亚偷拍自图区亚洲| 欧美日韩国产另类一区| 国产成人精品免费网站| 蜜臀av性久久久久蜜臀av麻豆| 欧美激情中文字幕| 午夜国产精品一区| 午夜欧美视频在线观看| 不卡在线观看av| 国产白丝精品91爽爽久久| 老司机精品视频导航| 麻豆91在线播放免费| 免费成人av资源网| 欧美亚洲国产一区二区三区va| 欧美中文字幕一二三区视频| 精品国产乱码久久久久久久| 亚洲成人综合在线| 成人免费毛片高清视频| 91老师国产黑色丝袜在线| 久久爱另类一区二区小说| 成人av片在线观看| 亚洲国产中文字幕| 国产酒店精品激情| 91精品国产综合久久久久久漫画 | 男人操女人的视频在线观看欧美| 国产亚洲欧美日韩在线一区| 国精产品一区一区三区mba桃花| 成人一级黄色片| 色偷偷久久人人79超碰人人澡| 精品国产乱码久久久久久蜜臀| 久久亚洲捆绑美女| 91国偷自产一区二区使用方法| 色综合久久中文综合久久牛| 成人va在线观看| 中文字幕亚洲欧美在线不卡| 国产校园另类小说区| 一本一道久久a久久精品| 欧美无砖砖区免费| 欧美日韩国产在线播放网站| 国产成人啪午夜精品网站男同| 亚洲天天做日日做天天谢日日欢 | 一区二区三区高清在线| av网站免费线看精品| va亚洲va日韩不卡在线观看| 91精品一区二区三区在线观看| 久久无码av三级| 欧美国产欧美亚州国产日韩mv天天看完整 | 一区二区三区欧美| 日韩经典中文字幕一区| 国产精品996| 9人人澡人人爽人人精品| 欧美美女一区二区| 一区二区三区精品在线| 亚洲成av人**亚洲成av**| 国产99一区视频免费| 欧美岛国在线观看| 免费成人结看片| 成人激情图片网| 欧美精品vⅰdeose4hd| 国产精品国产三级国产普通话三级| 久久综合九色欧美综合狠狠 | 一区二区三区久久| 亚洲成人tv网| 精品国产髙清在线看国产毛片| 日本va欧美va精品| 国产一区二区精品在线观看| 欧美日韩在线播放一区| 亚洲国产综合91精品麻豆| 国产日韩欧美精品在线| 久久成人久久爱| 欧美日精品一区视频| 91麻豆精品国产无毒不卡在线观看| 久久国产精品第一页| 日韩欧美成人激情| 青青青伊人色综合久久| 欧美日韩亚洲综合一区| 亚洲精品免费在线观看| 成人av免费网站| 日韩久久久精品| 亚洲情趣在线观看| 欧美欧美欧美欧美首页| 国模套图日韩精品一区二区| 国产亚洲综合色|