日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL索引的分类、何时使用、何时不使用、何时失效?

發布時間:2025/3/20 数据库 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL索引的分类、何时使用、何时不使用、何时失效? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
點擊上方?好好學java?,選擇?星標?公眾號重磅資訊,干貨,第一時間送達 今日推薦:14 個 github 項目!個人原創100W +訪問量博客:點擊前往,查看更多

? 作者:繞遠的偶人

blog.csdn.net/weixin_39420024/article/details/80040549

1、分類

MySQL索引分為普通索引、唯一索引、主鍵索引、組合索引、全文索引。索引不會包含有null值的列,索引項可以為null(唯一索引、組合索引等),但是只要列中有null值就不會被包含在索引中。

(1)普通索引: create index index_name on table(column);

或者創建表時指定,create table(..., index index_name column);

(2)唯一索引: 類似普通索引,索引列的值必須唯一(可以為空,這點和主鍵索引不同)

create unique index index_name on table(column);或者創建表時指定unique index_name column

(3)主鍵索引: 特殊的唯一索引,不允許為空,只能有一個,一般是在建表時指定primary key(column)

(4)組合索引: 在多個字段上創建索引,遵循最左前綴原則。alter table t add index index_name(a,b,c);

(5)全文索引: 主要用來查找文本中的關鍵字,不是直接與索引中的值相比較,像是一個搜索引擎,配合match against使用,現在只有char,varchar,text上可以創建全文索引。

在數據量較大時,先將數據放在一張沒有全文索引的表里,然后再利用create index創建全文索引,比先生成全文索引再插入數據快很多。

2、何時使用索引

MySQL每次查詢只使用一個索引。與其說是“數據庫查詢只能用到一個索引”,倒不如說,和全表掃描比起來,去分析兩個索引B+樹更加耗費時間。所以where A=a and B=b這種查詢使用(A,B)的組合索引最佳,B+樹根據(A,B)來排序。

  • 主鍵,unique字段;

  • 和其他表做連接的字段需要加索引;

  • 在where里使用>,≥,=,<,≤,is null和between等字段;

  • 使用不以通配符開始的like,where A like 'China%';

  • 聚集函數MIN(),MAX()中的字段;

  • order by和group by字段;

  • 3、何時不使用索引

  • 表記錄太少;

  • 數據重復且分布平均的字段(只有很少數據值的列);

  • 經常插入、刪除、修改的表要減少索引;

  • text,image等類型不應該建立索引,這些列的數據量大(假如text前10個字符唯一,也可以對text前10個字符建立索引);

  • MySQL能估計出全表掃描比使用索引更快時,不使用索引;

  • 4、索引何時失效

  • 組合索引未使用最左前綴,例如組合索引(A,B),where B=b不會使用索引;

  • like未使用最左前綴,where A like '%China';

  • 搜索一個索引而在另一個索引上做order by,where A=a order by B,只使用A上的索引,因為查詢只使用一個索引 ;

  • or會使索引失效。如果查詢字段相同,也可以使用索引。例如where A=a1 or A=a2(生效),where A=a or B=b(失效)

  • 如果列類型是字符串,要使用引號。例如where A='China',否則索引失效(會進行類型轉換);

  • 在索引列上的操作,函數(upper()等)、or、!=(<>)、not in等;

  • 5、explain語句

    type字段為All,未使用索引;為ref,使用索引

    • ALL: 全表掃描

    • index: 索引全掃描

    • range: 索引范圍掃描,常用語<,<=,>=,between等操作

    • ref: 使用非唯一索引掃描或唯一索引前綴掃描,返回單條記錄,常出現在關聯查詢中

    • eq_ref: 類似ref,區別在于使用的是唯一索引,使用主鍵的關聯查詢

    • const/system: 單條記錄,系統會把匹配行中的其他列作為常數處理,如主鍵或唯一索引查詢

    • null: MySQL不訪問任何表或索引,直接返回結果

    還有key字段表示用到的索引,沒有用到為null

    推薦文章
    • 開發者工具 Top 100 名單

    • 2020年國內互聯網公司的薪酬排名!

    • 不要再封裝各種Util工具類了,這個神級框架值得擁有!

    • 寫博客能月入10K?

    • 一款基于 Spring Boot 的現代化社區(論壇/問答/社交網絡/博客)

    更多項目源碼
    • 這或許是最美的Vue+Element開源后臺管理UI

    • 推薦一款高顏值的 Spring Boot 快速開發框架

    • 一款基于 Spring Boot 的現代化社區(論壇/問答/社交網絡/博客)

    • 13K點贊都基于 Vue+Spring 前后端分離管理系統ELAdmin,大愛

    • 想接私活時薪再翻一倍,建議根據這幾個開源的SpringBoot項目

    總結

    以上是生活随笔為你收集整理的MySQL索引的分类、何时使用、何时不使用、何时失效?的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。