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

首頁 > 數據庫 > MySQL > 正文

MySQL中有哪些情況下數據庫索引會失效詳析

2024-07-25 19:08:37
字體:
來源:轉載
供稿:網友

前言

要想分析MySQL查詢語句中的相關信息,如是全表查詢還是部分查詢,就要用到explain.

索引的優點

  • 大大減少了服務器需要掃描的數據量
  • 可以幫助服務器避免排序或減少使用臨時表排序
  • 索引可以隨機I/O變為順序I/O

索引的缺點

  • 需要占用磁盤空間,因此冗余低效的索引將占用大量的磁盤空間
  • 降低DML性能,對于數據的任意增刪改都需要調整對應的索引,甚至出現索引分裂
  • 索引會產生相應的碎片,產生維護開銷

一、explain

用法:explain +查詢語句。

MySQL,數據庫,索引

id:查詢語句的序列號,上面圖片中只有一個select 語句,所以只會顯示一個序列號。如果有嵌套查詢,如下

MySQL,數據庫,索引

select_type:表示查詢類型,有以下幾種

  simple:簡單的 select (沒有使用 union或子查詢)

  primary:最外層的 select。

  union:第二層,在select 之后使用了 union。

  dependent union:union 語句中的第二個select,依賴于外部子查詢

  subquery:子查詢中的第一個 select

  dependent subquery:子查詢中的第一個 subquery依賴于外部的子查詢

  derived:派生表 select(from子句中的子查詢)

table:查詢的表、結果集

type:全稱為"join type",意為連接類型。通俗的講就是mysql查找引擎找到滿足SQL條件的數據的方式。其值為:

  • system:系統表,表中只有一行數據
  • const:讀常量,最多只會有一條記錄匹配,由于是常量,實際上只須要讀一次。
  • eq_ref:最多只會有一條匹配結果,一般是通過主鍵或唯一鍵索引來訪問。
  • ref:對于每個來自于前面的表的行組合,所有有匹配索引值的行將從這張表中讀取
  • fulltext:進行全文索引檢索。
  • ref_or_null:與ref的唯一區別就是在使用索引引用的查詢之外再增加一個空值的查詢。
  • index_merge:查詢中同時使用兩個(或更多)索引,然后對索引結果進行合并,再讀取表數據。
  • unique_subquery:子查詢中的返回結果字段組合是主鍵或者唯一約束。
  • index_subquery:子查詢中的返回結果字段組合是一個索引(或索引組合),但不是一個主鍵或唯一索引。
  • rang:索引范圍掃描。
  • index:全索引掃描。
  • all:全表掃描。

  性能從上到下依次降低。

possible_keys:可能用到的索引

key:使用的索引

ref:ref列顯示使用哪個列或常數與key一起從表中選擇行。

rows:顯示MySQL認為它執行查詢時必須檢查的行數。多行之間的數據相乘可以估算要處理的行數。

Extra:額外的信息

  • Distinct:MySQL發現第1個匹配行后,停止為當前的行組合搜索更多的行。
  • Not exists:MySQL能夠對查詢進行LEFT JOIN優化,發現1個匹配LEFT JOIN標準的行后,不再為前面的的行組合在該表內檢查更多的行。
  • range checked for each record (index map: #):MySQL沒有發現好的可以使用的索引,但發現如果來自前面的表的列值已知,可能部分索引可以使用。
  • Using filesort:MySQL需要額外的一次傳遞,以找出如何按排序順序檢索行。
  • Using index:從只使用索引樹中的信息而不需要進一步搜索讀取實際的行來檢索表中的列信息。
  • Using temporary:為了解決查詢,MySQL需要創建一個臨時表來容納結果。
  • Using where:WHERE 子句用于限制哪一個行匹配下一個表或發送到客戶。
  • Using sort_union(...), Using union(...), Using intersect(...):這些函數說明如何為index_merge聯接類型合并索引掃描。
  • Using index for group-by:類似于訪問表的Using index方式,Using index for group-by表示MySQL發現了一個索引,可以用來查 詢GROUP BY或DISTINCT查詢的所有列,而不要額外搜索硬盤訪問實際的表。

二、數據庫不使用索引的情況

下面舉的例子中,GudiNo、StoreId列都有單獨的索引。

2.1、like查詢已 '%...'開頭,以'xxx%'結尾會繼續使用索引。

下圖中第一句使用的%,沒有使用索引,從rows為224147,使用索引rows為1。

    MySQL,數據庫,索引

2.2 where語句中使用 <>和 !=

MySQL,數據庫,索引

2.3 where語句中使用 or,但是沒有把or中所有字段加上索引。

MySQL,數據庫,索引

這種情況,如果需要使用索引需要將or中所有的字段都加上索引。

2.4 where語句中對字段表達式操作

MySQL,數據庫,索引

2.5 where語句中使用Not In

MySQL,數據庫,索引

看了別人寫的文章,有說“應盡量避免在where 子句中對字段進行null 值判斷,否則將導致引擎放棄使用索引而進行全表掃描”,實測沒有全表掃描。

MySQL,數據庫,索引

"對于多列索引,不是使用的第一部分,則不會使用索引",實測即使多索引,沒有使用第一部分,也會命中索引,沒有全表掃描。

MySQL,數據庫,索引

總結

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


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国产成人久久综合| 亚洲欧美日韩直播| 久久亚洲私人国产精品va| 国产精品日本精品| 亚洲一区精品电影| 成人av.网址在线网站| 国产精品美女午夜av| 亚洲精品99999| 久热99视频在线观看| 97在线视频免费看| 日韩一二三在线视频播| 国产aⅴ夜夜欢一区二区三区| www.日韩免费| 亚洲自拍小视频| 亚洲欧美在线一区二区| 欧美综合第一页| 欧美日韩在线视频观看| 国产一区二区成人| 国产精品老牛影院在线观看| 亚洲美女av网站| 视频在线观看一区二区| 久久久精品免费| 欧美精品福利视频| 亚洲sss综合天堂久久| 91精品久久久久久久久中文字幕| 欧美成人激情在线| 亚洲一区二区久久久久久| 久久久久久久久久久网站| 亚洲人成五月天| 日韩av在线资源| 日韩精品极品毛片系列视频| 欧美日韩国产专区| 国产精品视频免费在线观看| 日本免费在线精品| 亚洲成人网久久久| 色哟哟网站入口亚洲精品| 狠狠操狠狠色综合网| 热re99久久精品国产66热| 国产自产女人91一区在线观看| 亚洲最大在线视频| 国产精品欧美日韩一区二区| 秋霞午夜一区二区| 精品精品国产国产自在线| 国产综合色香蕉精品| 美女国内精品自产拍在线播放| 亚洲男女性事视频| 亚洲欧美日韩中文在线| 91久久夜色精品国产网站| 欧美国产在线电影| 日韩在线播放视频| 欧美高清在线视频观看不卡| 国产成人免费av| 欧美视频中文字幕在线| 91网站免费看| 亚洲视频电影图片偷拍一区| 国产成人涩涩涩视频在线观看| 91国产视频在线| 日韩精品视频免费专区在线播放| 亚洲一二在线观看| 日韩欧美一区二区三区久久| 26uuu另类亚洲欧美日本老年| 久久久久久这里只有精品| 国内精品小视频在线观看| 日本一区二区三区在线播放| 最近2019中文字幕第三页视频| 久久伊人色综合| 欧美精品激情在线| 欧美大片在线免费观看| 日韩综合中文字幕| 日韩精品极品视频免费观看| 国产精品久久久久久五月尺| 91大神在线播放精品| 亚洲自拍欧美色图| 在线视频精品一| 日韩美女免费视频| 欧美性在线观看| 亚洲精品成a人在线观看| 欧美激情videoshd| 亚洲精品一区二三区不卡| 亚洲一级黄色av| 国产精品91免费在线| 欧美日韩在线免费观看| 欧美中文在线免费| 欧美猛交ⅹxxx乱大交视频| 久久天天躁狠狠躁夜夜爽蜜月| 欧美裸体男粗大视频在线观看| 萌白酱国产一区二区| 青草青草久热精品视频在线网站| 98视频在线噜噜噜国产| 日韩国产欧美区| 色先锋久久影院av| 日韩视频免费中文字幕| 欧美精品videosex牲欧美| 日韩精品免费看| 久久精品小视频| 爱福利视频一区| 成人精品一区二区三区| 欧美性受xxxx白人性爽| 久久精品国产精品亚洲| 亚洲电影第1页| 亚洲一区二区久久久久久| 亚洲人成网站在线播| 日韩精品欧美激情| 国产成人+综合亚洲+天堂| 亚洲天堂男人天堂| 青青久久av北条麻妃黑人| 精品久久久久久久久久| 欧美国产高跟鞋裸体秀xxxhd| 日韩成人av在线播放| 神马久久久久久| 欧美精品做受xxx性少妇| 尤物精品国产第一福利三区| 亚洲免费视频网站| 中文字幕日韩有码| 国产欧亚日韩视频| 欧美性在线观看| 国产v综合ⅴ日韩v欧美大片| 亚洲国产精品悠悠久久琪琪| 亚洲天堂精品在线| 亚洲图片欧洲图片av| 久久久久久亚洲精品中文字幕| 久色乳综合思思在线视频| 国产精品网站大全| 欧美日韩一区二区免费视频| 亚洲激情成人网| 欧美在线观看一区二区三区| 最近2019年日本中文免费字幕| 欧美电影院免费观看| 久久精品国产视频| 亚洲最大av网| 亚洲精选一区二区| 欧美丝袜一区二区三区| 97av在线播放| 免费97视频在线精品国自产拍| 91精品国产91久久久久久最新| 国产97色在线|日韩| 久久精品国产亚洲一区二区| 国产婷婷成人久久av免费高清| 一色桃子一区二区| 欧美激情亚洲精品| 国产自摸综合网| 亚洲天堂色网站| 欧洲一区二区视频| 欧美午夜激情在线| 亚洲aⅴ男人的天堂在线观看| 精品国内亚洲在观看18黄| 国产视频久久久久久久| 久久夜色精品亚洲噜噜国产mv| 欧美激情一区二区三区久久久| 国产99久久久欧美黑人| 亚洲人成电影在线观看天堂色| 啊v视频在线一区二区三区| 正在播放欧美视频| 欧美交受高潮1| 欧美黑人巨大精品一区二区| 亚洲成**性毛茸茸| 欧美一区二区三区艳史| 亚洲色图综合久久| 亚洲欧美日韩在线高清直播| 色综合久久久久久中文网| 久久综合亚洲社区| 国产日韩欧美中文| 日韩黄色高清视频| 国产精品久久久久91|