亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

關于MySQL索引的深入解析

2020-01-18 20:39:23
字體:
來源:轉載
供稿:網友

前言

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

使用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字段:表示關于哪張表;
type字段:system,const,eq_reg,ref,range,index,all。一般來說要達到range級別以上;

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

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

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

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

rows字段:MySQL認為檢索需要的數據行數;

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

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

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

MySQL怎么計算需要檢索的行數

實際中,MySQL所統計的掃描行數并不是精確值,有時候甚至會相差很遠,而掃描行數則是基于索引的基數來計算的。

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

在MySQL中,有2種存儲索引統計的方式,可以通過設置innodb_stats_persistent參數來選擇:

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

設置為 off 的時候,表示統計信息只存儲在內存中。這時,默認的 N 是 8,M 是 16。

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

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

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

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

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

2、轉換思路,優化一下sql語句可能就會使用到該使用的索引。

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

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美一区二区三区久久| 日韩69视频在线观看| 亚洲最大的网站| 久久男人资源视频| 亚洲精品日韩丝袜精品| 欧美性猛交xxxx免费看漫画| 欧美精品在线视频观看| 97精品国产97久久久久久春色| 亚洲人成在线电影| 成人乱人伦精品视频在线观看| 91啪国产在线| 成人福利在线视频| 法国裸体一区二区| 国模gogo一区二区大胆私拍| 亚洲福利视频网站| 国产精品96久久久久久| 亚洲精品动漫久久久久| 国语自产精品视频在免费| 日韩小视频在线| 在线观看国产精品日韩av| 久操成人在线视频| 在线电影欧美日韩一区二区私密| 青青草原成人在线视频| 中文字幕亚洲欧美日韩2019| 日本一本a高清免费不卡| 8x拔播拔播x8国产精品| 久久久影视精品| 92看片淫黄大片看国产片| 久久久免费电影| 精品国内亚洲在观看18黄| 欧美日韩在线一区| 亚洲精品久久久久久久久久久| 国产91色在线免费| 成人久久18免费网站图片| 亚洲国产高潮在线观看| 日韩美女在线看| 国产成人精品免费视频| 欧美尤物巨大精品爽| 国模私拍一区二区三区| 精品电影在线观看| 国产乱人伦真实精品视频| 日本免费久久高清视频| 国产精品久久在线观看| 国产精品aaaa| 欧美限制级电影在线观看| 国产成人亚洲精品| 日韩一区二区久久久| 国产精品视频免费在线| 性欧美xxxx视频在线观看| 国产欧美最新羞羞视频在线观看| 亚洲精品久久在线| 精品高清美女精品国产区| 欧洲亚洲免费视频| 亚洲一区亚洲二区亚洲三区| www.日韩不卡电影av| 欧美性xxxxx极品娇小| 欧美成人精品在线| 九九热r在线视频精品| 亚洲天堂一区二区三区| 欧美肥婆姓交大片| 日韩在线观看av| 中文字幕一区电影| www.日韩av.com| 欧美孕妇毛茸茸xxxx| 成人网欧美在线视频| 亚洲欧美在线第一页| 国产亚洲精品va在线观看| 欧美激情一二三| 亚洲激情自拍图| 1769国内精品视频在线播放| 欧美日韩午夜视频在线观看| 欧美高跟鞋交xxxxhd| 成人中文字幕在线观看| 成人h视频在线观看播放| 国产男女猛烈无遮挡91| 日本不卡高字幕在线2019| 久久久久久一区二区三区| 亚洲欧美国产日韩天堂区| 欧美电影免费观看电视剧大全| 91免费精品视频| 欧美精品成人在线| 欧美精品在线观看| 国产亚洲日本欧美韩国| 日韩三级影视基地| 欧美日韩另类在线| 成人欧美一区二区三区在线| 欧美精品在线免费观看| 国产999精品视频| 欧美wwwwww| 日韩美女av在线| 2019中文字幕全在线观看| 国产精品777| 亚洲精品国产综合久久| 成人激情综合网| 日韩视频免费在线| 日韩成人激情视频| 国产精品成人aaaaa网站| 91久久夜色精品国产网站| 欧美精品一区二区免费| 亚洲欧美在线一区| 91久久国产综合久久91精品网站| 国产精品久久久久久久久借妻| 久久久视频精品| 亚洲欧美一区二区精品久久久| 欧美午夜精品伦理| 国产精品久久久| 欧美精品电影免费在线观看| 欧美激情精品久久久久久黑人| 欧美日韩免费网站| 久久综合伊人77777| 中文字幕成人精品久久不卡| 日韩欧美中文字幕在线观看| 亚洲欧美综合精品久久成人| 欧美日韩国产精品| 亚洲欧美中文日韩在线v日本| 不卡中文字幕av| 一区二区三区四区在线观看视频| 国产精品久久久久久亚洲影视| 欧美日韩在线影院| 97精品国产97久久久久久春色| 97免费视频在线播放| 另类视频在线观看| 日韩在线中文视频| 尤物yw午夜国产精品视频明星| 亚洲国产欧美精品| 欧美另类极品videosbestfree| 日韩免费av一区二区| 日本免费一区二区三区视频观看| 国产精品免费久久久久久| 九九视频这里只有精品| 亚洲xxxxx| 欧美高跟鞋交xxxxhd| 国产激情久久久久| 久久人人看视频| 亚洲人成在线观看网站高清| 日韩在线激情视频| 久久亚洲精品网站| 2019最新中文字幕| 在线电影欧美日韩一区二区私密| 欧美精品videos性欧美| 97在线视频免费| 国产精品久久久久久网站| 欧美最猛性xxxxx亚洲精品| 777午夜精品福利在线观看| 福利一区视频在线观看| 久久视频在线免费观看| 久久久久一本一区二区青青蜜月| 国产精品高潮呻吟久久av野狼| 亚洲国产婷婷香蕉久久久久久| 亚洲欧美色图片| 精品福利免费观看| 日韩成人激情在线| 国内精品免费午夜毛片| 91视频国产一区| 国产一区二区精品丝袜| 自拍偷拍亚洲一区| 国产噜噜噜噜久久久久久久久| 国产91在线视频| 亚洲国产91色在线| 欧美激情中文字幕在线| 在线激情影院一区| 国产第一区电影| 8090成年在线看片午夜| 91视频8mav|