国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

mysql下普通索引和唯一索引的效率對比

2024-07-24 13:03:26
字體:
來源:轉載
供稿:網友

今天在我的虛擬機中布置了環境,測試抓圖如下:

mysql下普通索引和唯一索引的效率對比

抓的這幾個都是第一次執行的,刷了幾次后,取平均值,效率大致相同,而且如果在一個列上同時建唯一索引和普通索引的話,mysql會自動選擇唯一索引。

谷歌一下:

唯一索引和普通索引使用的結構都是B-tree,執行時間復雜度都是O(log n)。

補充下概念:

1、普通索引

 

  普通索引(由關鍵字KEY或INDEX定義的索引)的唯一任務是加快對數據的訪問速度。因此,應該只為那些最經常出現在查詢條件(WHEREcolumn=)或排序條件(ORDERBYcolumn)中的數據列創建索引。只要有可能,就應該選擇一個數據最整齊、最緊湊的數據列(如一個整數類型的數據列)來創建索引。

2、唯一索引

  普通索引允許被索引的數據列包含重復的值。比如說,因為人有可能同名,所以同一個姓名在同一個“員工個人資料”數據表里可能出現兩次或更多次。

如果能確定某個數據列將只包含彼此各不相同的值,在為這個數據列創建索引的時候就應該用關鍵字UNIQUE把它定義為一個唯一索引。這么做的好處:一是簡化了MySQL對這個索引的管理工作,這個索引也因此而變得更有效率;二是MySQL會在有新記錄插入數據表時,自動檢查新記錄的這個字段的值是否已經在某個記錄的這個字段里出現過了;如果是,MySQL將拒絕插入那條新記錄。也就是說,唯一索引可以保證數據記錄的唯一性。事實上,在許多場合,人們創建唯一索引的目的往往不是為了提高訪問速度,而只是為了避免數據出現重復。

注:

終于找到同事說執行效率不一樣的原因了,他在普通索引上創建的是前綴索引,只取了前16個字節,而唯一索引使用的全字節 :)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 乐业县| 思茅市| 平泉县| 德惠市| 岑溪市| 无棣县| 永清县| 西吉县| 九寨沟县| 乐山市| 醴陵市| 静乐县| 韶关市| 上饶市| 宁河县| 石城县| 涟源市| 平定县| 万州区| 台湾省| 杭锦后旗| 青冈县| 崇明县| 安徽省| 孝感市| 休宁县| 四会市| 抚远县| 朝阳区| 长沙县| 班玛县| 怀仁县| 中方县| 当雄县| 抚宁县| 永新县| 陈巴尔虎旗| 昭苏县| 永胜县| 陆河县| 高邑县|