欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于MySQL索引的深入解析

 更新時間:2019年11月21日 08:33:16   作者:風雨之間  
這篇文章主要給大家介紹了關(guān)于MySQL索引的深入解析,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

前言

我們知道,索引的選擇是優(yōu)化器階段的工作,但是優(yōu)化器并不是萬能的,它有可能選錯所要使用的索引。一般優(yōu)化器選擇索引考慮的因素有:掃描行數(shù),是否排序,是否使用臨時表。

使用explain分析sql

explain是很好的自測命令,勤于使用explain有助于我們寫出更合理的sql語句以及建立更合理的索引:

mysql> explain select * from t where (a between 1 and 1000) and (b between 50000 and 100000) order by b limit 1;
+----+-------------+-------+------------+-------+---------------+------+---------+------+-------+----------+------------------------------------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra               |
+----+-------------+-------+------------+-------+---------------+------+---------+------+-------+----------+------------------------------------+
| 1 | SIMPLE   | t   | NULL    | range | a,b      | b  | 5    | NULL | 50223 |   1.00 | Using index condition; Using where |
+----+-------------+-------+------------+-------+---------------+------+---------+------+-------+----------+------------------------------------+
1 row in set, 1 warning (0.01 sec)

其中:

table字段:表示關(guān)于哪張表;
type字段:system,const,eq_reg,ref,range,index,all。一般來說要達到range級別以上;

system、const:可以將查詢的變量轉(zhuǎn)為常量,如id=1;id為主鍵或唯一鍵;
eq_ref:訪問索引,返回某單一行的數(shù)據(jù),通常在連接時出現(xiàn),查詢使用的索引為主鍵或唯一鍵;
ref:訪問索引,返回某個值得數(shù)據(jù)(可能是多行),通常使用=時發(fā)生;
range:使用索引返回一個范圍內(nèi)的行信息,如使用>,<,between
index:以索引的順序進行全表掃描,雖然有索引不用排序,但是要全表掃描;
all:全表掃描

key字段:實際使用的索引;

key_len字段:使用的索引長度(在不損失精度的情況下,長度越短越好);

ref字段:顯示索引的哪一列被使用了;

rows字段:MySQL認為檢索需要的數(shù)據(jù)行數(shù);

Extra字段:查詢的額外信息,主要有以下幾種:

using index:使用了索引
using where:使用了where條件
using tmporary:用到臨時表去處理當前查詢
using filesort:用到額外的排序,如order字段無索引
range checked for eache record(index map:N):無索引可用
using index for group-by:表名可以在索引中找到分組所需的所有數(shù)據(jù),不需要查詢實際的表

一般遇到Using temporary和Using filesort就要想辦法優(yōu)化一下了,因為用不到索引。

MySQL怎么計算需要檢索的行數(shù)

實際中,MySQL所統(tǒng)計的掃描行數(shù)并不是精確值,有時候甚至?xí)嗖詈苓h,而掃描行數(shù)則是基于索引的基數(shù)來計算的。

在MySQL中,通過采樣統(tǒng)計的方式去獲取索引基數(shù):系統(tǒng)默認選取 N 個數(shù)據(jù)頁,統(tǒng)計數(shù)據(jù)頁上不同值得平均值,然后乘以索引的頁面數(shù)得到基數(shù),而且MySQL會在變更的數(shù)據(jù)行數(shù)超過 1/M 時來觸發(fā)重做索引統(tǒng)計的操作。

在MySQL中,有2種存儲索引統(tǒng)計的方式,可以通過設(shè)置innodb_stats_persistent參數(shù)來選擇:

設(shè)置為 on 的時候,表示統(tǒng)計信息會持久化存儲。這時,默認的 N 是 20,M 是 10。

設(shè)置為 off 的時候,表示統(tǒng)計信息只存儲在內(nèi)存中。這時,默認的 N 是 8,M 是 16。

一般來說,基數(shù)統(tǒng)計出來的數(shù)據(jù)和真實的行數(shù)沒有很大差距,但是涉及到刪除數(shù)據(jù)新增數(shù)據(jù)比較頻繁的數(shù)據(jù)表,可能會出現(xiàn)數(shù)據(jù)表有10萬條數(shù)據(jù)但是基數(shù)統(tǒng)計卻有20萬的情況,這就可能是MVCC在作怪了,因為MySQL的InnoDB的事務(wù)支持,需要維持多個數(shù)據(jù)版本,就有可能某些事務(wù)還沒結(jié)束,還在使用刪除了很久的數(shù)據(jù)導(dǎo)致已刪除的數(shù)據(jù)空間無法釋放,而新增的數(shù)據(jù)又開辟了新的空間,那么這時候就導(dǎo)致基數(shù)統(tǒng)計中數(shù)據(jù)頁數(shù)量可能出現(xiàn)失誤,出現(xiàn)較大誤差。

一個很好的修正方式就是執(zhí)行analyze table 表名,該命令用來重新統(tǒng)計索引信息。

索引選錯了我們到底怎么辦

當我們正確的建立必須的索引后,大部分情況下,優(yōu)化器其實并不會選擇錯索引,當我們遇到索引選錯的情況下,該怎么去處理呢?

1、使用force index強制使用某個索引。

2、轉(zhuǎn)換思路,優(yōu)化一下sql語句可能就會使用到該使用的索引。

3、新建更合適的索引或刪除掉誤用到的不合理的索引。(有些時候,可能真的是這個索引是多余的,還不是最優(yōu)的,優(yōu)化器又剛好使用到了它)。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。

相關(guān)文章

  • MySQL范圍查詢優(yōu)化的場景實例詳解

    MySQL范圍查詢優(yōu)化的場景實例詳解

    范圍訪問方法使用單一索引去檢索表中的數(shù)據(jù)包含一個或者多個索引值的行記錄,下面這篇文章主要給大家介紹了關(guān)于MySQL范圍查詢優(yōu)化的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • Mysql多表關(guān)聯(lián)不走索引的原因及分析

    Mysql多表關(guān)聯(lián)不走索引的原因及分析

    這篇文章主要介紹了Mysql多表關(guān)聯(lián)不走索引的原因及分析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • MySQL優(yōu)化之分區(qū)表

    MySQL優(yōu)化之分區(qū)表

    這篇文章主要介紹了MySQL優(yōu)化之分區(qū)表,需要的朋友可以參考下
    2016-06-06
  • Mysql中常用的幾種join連接方式總結(jié)

    Mysql中常用的幾種join連接方式總結(jié)

    join語句是面試中經(jīng)常會讓你現(xiàn)場寫出來的語句,下面這篇文章主要給大家介紹了關(guān)于Mysql中常用的幾種join連接方式,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-05-05
  • MySQL索引設(shè)計原則深入分析講解

    MySQL索引設(shè)計原則深入分析講解

    為了使索引的使用效率更高,在創(chuàng)建索引時,必須考慮在哪些字段上創(chuàng)建索引和創(chuàng)建什么類型的索引。索引設(shè)計不合理或者缺少索引都會對數(shù)據(jù)庫和應(yīng)用程序的性能造成障礙。高效的索引對于獲得良好的性能非常重要。設(shè)計索引時,應(yīng)該考慮相應(yīng)準則
    2023-01-01
  • mysql安裝報錯unknown variable mysqlx_port=0.0

    mysql安裝報錯unknown variable mysqlx_port=0.0

    本文主要介紹了mysql安裝報錯unknown variable mysqlx_port=0.0,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-06-06
  • you *might* want to use the less safe log_bin_trust_function_creators variable

    you *might* want to use the less safe log_bin_trust_function

    you *might* want to use the less safe log_bin_trust_function_creators variable
    2011-07-07
  • 全面解析MySQL?Explain如何優(yōu)化SQL查詢性能

    全面解析MySQL?Explain如何優(yōu)化SQL查詢性能

    在?MySQL?中,EXPLAIN?關(guān)鍵字可以幫助我們分析查詢執(zhí)行計劃,從而優(yōu)化查詢性能,所以本文就來和大家詳細講講Explain是如何優(yōu)化SQL查詢性能的
    2023-05-05
  • linux下啟動或者關(guān)閉MySQL數(shù)據(jù)庫的多種方式

    linux下啟動或者關(guān)閉MySQL數(shù)據(jù)庫的多種方式

    ,在Linux服務(wù)器上管理MySQL服務(wù)是一個基本的運維任務(wù),下面這篇文章主要給大家介紹了關(guān)于linux下啟動或者關(guān)閉MySQL數(shù)據(jù)庫的多種方式,文中通過代碼以及圖文介紹的非常詳細,需要的朋友可以參考下
    2024-06-06
  • MySQL中Bit數(shù)據(jù)類型的使用方式

    MySQL中Bit數(shù)據(jù)類型的使用方式

    這篇文章主要介紹了MySQL中Bit數(shù)據(jù)類型的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09

最新評論