亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL數據庫緩存原理是什么

發布時間:2021-08-13 16:18:12 來源:億速云 閱讀:159 作者:Leah 欄目:數據庫

今天就跟大家聊聊有關MySQL數據庫緩存原理是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

  MySQL數據庫查詢步驟有哪些

  當MySQL收到客戶端發送的查詢語句時,首先會檢查緩存塊中是否緩存中此語句的結果,如果有,則檢查權限,如果能通過權限的檢查則直接返回緩存塊中的結果集,我們稱之為命中緩存,此時會增加Qcache_hits變量的值。

  如果在緩存中找不到此語句的緩存(此時會增加Com_select變量的值),則進入下一步:

  1、MySQL解析器將查詢語句分解成一個個標識,并建立一棵“解析樹”,解析器會使用MySQL的語法解析和驗證這個查詢語句的標識的有效性及標識是否出現在適當的位置上,它還會檢查字符串中的引號有沒有閉合。

  2、預處理器會檢查此“解析樹”中的表和列是否存在,列的別名是否混淆,最后就是對權限的檢查,而這些檢查特性是解析器不具備的,只能通過預處理器來完成。

  3、如果前面兩步都通過了檢驗,MySQL的優化器則對“解析樹”進行優化,并根據所預測的執行成本來生成執行成本最低的執行計劃。最后執行此計劃,存儲查詢結果,返回結果集給客戶端。

  通過上述兩個變量值,我們可以通過這個公式計算出緩存的命中率:Qcache_hits/(Qcache_hits_Com_select),通過命中率來查看我們是否可以從緩存中獲益。這里有一個問題就是:命中率的多少才是最好的呢?這個沒有確定值的,要根據情況而定,如果命中的是那些要篩選大量數據才得到的結果的查詢語句(比如說:GROUPBY,COUNT等),即使命中率很低,但這也是一個很好的命中率值。

  MySQL數據庫緩存原理有哪些

  1、所發送的查詢語句是不可緩存的,查詢語句不可緩存的原因有兩種:語句包含了不確定值,如CURRENT_DATE,。所得到的結果集太大而無法將它保存到緩存中.這兩種原因造成的結果都會增加Qcache_not_cached變量的值,我們可以查看這個變量的值來檢查我們查詢語句的緩存情況.

  2、所發送的查詢語句之前沒有發送過(第一次發送),所以也不會有什么緩存存在。

  3、所發送的查詢語句的結果集之前是存在于緩存中的,但由于內存不足,MySQL不得不將之前的一些緩存清除,以騰出空間來放置其它新的緩存結果。同樣,數據的變更也會引發緩存的失效。比如(更新,刪除,插入)。如果是數據的變量引起緩存的失效的話,我們可以通過查看Com_*變量的值來確認有多少查詢語句更改了數據,這些變量為:Com_update,Com_delete等等。

看完上述內容,你們對MySQL數據庫緩存原理是什么有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

三穗县| 庆城县| 凤翔县| 法库县| 西华县| 赣榆县| 抚顺县| 古蔺县| 怀仁县| 双桥区| 新宾| 富锦市| 肃南| 安陆市| 精河县| 平南县| 马关县| 且末县| 石城县| 沂南县| 怀集县| 四会市| 耒阳市| 商丘市| 兴义市| 莱州市| 伊吾县| 高尔夫| 白河县| 余庆县| 汝城县| 乾安县| 申扎县| 衢州市| 保亭| 柘城县| 绍兴县| 新绛县| 沅陵县| 江城| 浦江县|