激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - MySQL中有哪些情況下數據庫索引會失效詳析

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

2019-07-07 15:14MicroHeart! Mysql

這篇文章主要給大家介紹了關于MySQL中有哪些情況下數據庫索引會失效的相關資料,文中通過圖文介紹的非常詳細,對大家學習或者使用mysql具有一定的參考學習價值,需要的朋友們下面隨著小

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

一、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.2where語句中使用 <>和 !=

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

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

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

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

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

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

2.5where語句中使用Not In

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

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

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

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

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

總結

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩三级伦理在线观看 | 日韩欧美电影一区二区三区 | 欧美毛片免费观看 | 黄色网址你懂的 | 国产精品九九久久一区hh | 欧美自拍三区 | 国产亚洲精品网站 | 狠狠婷婷综合久久久久久妖精 | 国产欧美精品一区二区三区四区 | 国产日产精品久久久久快鸭 | 在线看一区二区三区 | 污在线观看网站 | 日本高清电影在线播放 | 香蕉成人在线观看 | 国产精品亚洲欧美一级在线 | 国产喷白浆10p | 97视频一二区 | 精品一区二区三区免费爱 | 日本在线看片 | 一级成人免费 | 精品国产一区二区在线 | 成人在线视频播放 | 亚洲第一成人久久网站 | 久久久久se | 正在播放91精 | 少妇一级淫片高潮流水电影 | 水多视频在线观看 | 免费嗨片首页中文字幕 | 欧美成人免费在线视频 | 国产羞羞视频 | 亚洲一区在线观看视频 | 亚洲一区二区三区精品在线观看 | 美女网站黄在线观看 | 91九色视频在线观看 | 成人免费观看av | 在线视频观看一区二区 | 国产精品久久久久久久久久久久午夜 | 伊人成人免费视频 | 石原莉奈日韩一区二区三区 | 成人在线观看一区二区三区 | 精品中文字幕久久久久四十五十骆 |