成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

面試官提問:什么是前綴索引?

數據庫 其他數據庫
本文主要圍繞前綴索引做了一次初步的知識講解,具體數據庫表索引的選擇性,還需要結合業務實際需求來考慮!

一、什么是前綴索引?

所謂前綴索引,說白了就是對文本的前幾個字符建立索引(具體是幾個字符在建立索引時去指定),比如以產品名稱的前 10 位來建索引,這樣建立起來的索引更小,查詢效率更快!

有點類似于 Oracle 中對字段使用 Left 函數來建立函數索引,只不過 MySQL 的這個前綴索引在查詢時是內部自動完成匹配的,并不需要使用 Left 函數。

二、為什么要用前綴索引?

可能有的同學會發出疑問,為什么不對整個字段建立索引呢?

一般來說,當某個字段的數據量太大,而且查詢又非常的頻繁時,使用前綴索引能有效的減小索引文件的大小,讓每個索引頁可以保存更多的索引值,從而提高了索引查詢的速度。

比如,客戶店鋪名稱,有的名稱很長,有的很短,如果完全按照全覆蓋來建索引,索引的存儲空間可能會非常的大,有的表如果索引創建的很多,甚至會出現索引存儲的空間都比數據表的存儲空間大很多,因此對于這種文本很長的字段,我們可以截取前幾個字符來建索引,在一定程度上,既能滿足數據的查詢效率要求,又能節省索引存儲空間。

但是另一方面,前綴索引也有它的缺點,MySQL 中無法使用前綴索引進行 ORDER BY 和 GROUP BY,也無法用來進行覆蓋掃描,當字符串本身可能比較長,而且前幾個字符完全相同,這個時候前綴索引的優勢已經不明顯了,就沒有創建前綴索引的必要了。

因此這又回到一個概念,那就是關于索引的選擇性!

關于數據庫表索引的選擇性,我會單獨開篇來講解,大家只需要記住一點:索引的選擇性越高則查詢效率越高,因為選擇性高的索引可以讓 MySQL 在查找時過濾掉更多的行,數據查詢速度更快!

當某個字段內容的前幾位區分度很高的時候,這個時候采用前綴索引,可以在查詢性能和空間存儲方面達到一個很高的性價比。

那么問題來了,怎么創建前綴索引呢?

三、怎么創建前綴索引?

建立前綴索引的方式,方法很簡單,通過如下方式即可創建!

ALTER TABLE table_name ADD KEY(column_name(prefix_length));

其中prefix_length這個參數,就是前綴長度的意思,通常通過如下方式進行確認,步驟如下:

第一步,先計算某字段全列的區分度。

SELECT COUNT(DISTINCT column_name) / COUNT(*) FROM table_name;

第二步,然后再計算前綴長度為多少時和全列的區分度最相似

SELECT COUNT(DISTINCT LEFT(column_name, prefix_length)) / COUNT(*) FROM table_name;

最后,不斷地調整prefix_length的值,直到和全列計算出區分度相近,最相近的那個值,就是我們想要的值。

下面以某個測試表為例,數據體量在 100 萬以上,表結構如下!

CREATE TABLE `tb_test` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(100) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;

圖片

圖片

測試一下正常的帶name條件查詢,效率如下:

select * from tb_test where name like '1805.59281427%'

圖片

圖片

我們以name?字段為例,創建前綴索引,找出最合適的prefix_length值。

首先,我們大致計算一下name字段全列的區分度。

圖片

可以看到,結果為 0.9945?,也就是說全局不相同的數據率在99.45%這個比例。

下面我們一起來看看,不同的prefix_length值下,對應的數據不重復比例。

當prefix_length為5?,區分度為0.2237

圖片

當prefix_length為10?,區分度為0.9944

圖片

當prefix_length為11?,區分度為0.9945

圖片

通過對比,我們發現當prefix_length為11?,最接近全局區分度,因此可以為name?創建一個長度為11的前綴索引,創建索引語句如下:

alter table tb_test add key(name(11));

下面,我們再試試上面那個語句查詢!

圖片

創建前綴索引之后,查詢效率倍增!

四、使用前綴索引需要注意的事項?

是不是所有的字段,都適合用前綴索引呢?

答案顯然不是,在上文我們也說到了,當某個索引的字符串列很大時,創建的索引也就變得很大,為了減小索引體積,提高索引的掃描速度,使用索引的前部分字符串作為索引值,這樣索引占用的空間就會大大減少,并且索引的選擇性也不會降低很多,這時前綴索引顯現的作用就會非常明顯,前綴索引本質是索引查詢性能和存儲空間的一種平衡。

對于 BLOB 和 TEXT 列進行索引,或者非常長的 VARCHAR 列,就必須使用前綴索引,因為 MySQL 不允許索引它們的全部長度。

但是如果某個字段內容,比如前綴部分相似度很高,此時的前綴索引顯現效果就不會很明顯,采用覆蓋索引效果會更好!

五、小結

好了,本文主要圍繞前綴索引做了一次初步的知識講解,具體數據庫表索引的選擇性,還需要結合業務實際需求來考慮!

今天就說這么多,后面的問題,我們繼續再扯!

責任編輯:武曉燕 來源: Java極客技術
相關推薦

2021-12-08 06:53:29

面試動態代理

2021-09-07 10:44:33

Java 注解開發

2024-02-22 15:36:23

Java內存模型線程

2023-12-06 09:10:28

JWT微服務

2021-02-19 10:02:57

HTTPSJava安全

2020-08-17 07:40:19

消息隊列

2021-04-19 18:56:58

大數字符串運算

2023-12-20 14:35:37

Java虛擬線程

2020-08-06 07:49:57

List元素集合

2021-05-12 08:20:53

開發

2025-03-10 07:05:07

2024-04-15 00:01:00

STWJava垃圾

2022-01-05 09:55:26

asynawait前端

2024-01-11 08:12:20

重量級監視器

2021-08-24 08:05:41

泛型類型擦除Class

2020-07-22 08:05:44

中間人攻擊

2019-04-15 14:40:46

消息隊列Java編程

2022-07-06 13:48:24

RedisSentinel機制

2025-03-05 00:01:00

ReduxReact

2023-10-12 07:35:45

面試線程通信
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 凹凸日日摸日日碰夜夜 | 国产精品99久久久久久www | 色婷婷一区二区三区四区 | 中文字幕在线观看视频网站 | 91在线网| 二区在线视频 | 国产中文字幕在线 | 91亚洲国产| 日本黄色片免费在线观看 | 91欧美精品成人综合在线观看 | 欧美一区二区网站 | 久久新视频 | 一级片免费在线观看 | 浴室洗澡偷拍一区二区 | 日韩精品视频在线播放 | 欧美九九 | 国产丝袜一区二区三区免费视频 | 日韩电影一区二区三区 | 天天看天天摸天天操 | 欧美在线一二三 | 操久久 | av一级久久 | 国产欧美久久一区二区三区 | 日本国产高清 | 综合久久综合久久 | 日韩精品一区二区三区四区视频 | 啪啪免费网 | 欧美一区二区三区 | 日韩av视屏| 国产乱性 | 国产精品视频网站 | 免费久久精品 | 中文成人在线 | 久久久91 | 欧美在线一区二区三区 | 国产精品毛片在线 | 综合五月婷 | 激情av网站 | 老司机午夜性大片 | 蜜桃av鲁一鲁一鲁一鲁 | 亚洲精品白浆高清久久久久久 |