国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区

掃一掃
關注微信公眾號

MySQL索引分類和各自用途
2009-05-08   hi.baidu

一、 MySQL: 索引以B樹格式保存

Memory存儲引擎可以選擇Hash或BTree索引,Hash索引只能用于=或<=>的等式比較。

1、普通索引:create index on Tablename(列的列表)

alter table TableName add index (列的列表)

create table TableName([...], index [IndexName] (列的列表)

2、唯一性索引:create unique index

alter ... add unique

主鍵:一種唯一性索引,必須指定為primary key

3、全文索引:從3.23.23版開始支持全文索引和全文檢索,FULLTEXT,

可以在char、varchar或text類型的列上創建。

4、單列索引、多列索引:

多個單列索引與單個多列索引的查詢效果不同,因為:

執行查詢時,MySQL只能使用一個索引,會從多個索引中選擇一個限制最為嚴格的索引。

5、最左前綴(Leftmost Prefixing):多列索引,例如:fname_lname_age索引,以下的搜索條件MySQL都將使用

fname_lname_age索引:firstname,lastname,age;firstname,lastname;firstname,其他情況將不使用。

二、根據sql查詢語句確定創建哪種類型的索引,如何優化查詢

選擇索引列:

a.性能優化過程中,選擇在哪個列上創建索引是最重要的步驟之一。可以考慮使用索引的主要有

兩種類型的列:在where子句中出現的列,在join子句中出現的列。

b.考慮列中值的分布,索引的列的基數越大,索引的效果越好。

c.使用短索引,如果對字符串列進行索引,應該指定一個前綴長度,可節省大量索引空間,提升查詢速度。

d.利用最左前綴

e.不要過度索引,只保持所需的索引。每個額外的索引都要占用額外的磁盤空間,并降低寫操作的性能。

在修改表的內容時,索引必須進行更新,有時可能需要重構,因此,索引越多,所花的時間越長。

MySQL只對一下操作符才使用索引:<,<=,=,>,>=,between,in,

以及某些時候的like(不以通配符%或_開頭的情形)。

熱詞搜索:

上一篇:淺談Oracle中的三種Join方法
下一篇:輕松掌握數據倉庫開發

分享到: 收藏
主站蜘蛛池模板: 东平县| 赞皇县| 望城县| 祥云县| 潼南县| 廉江市| 呼伦贝尔市| 金寨县| 乐业县| 平顺县| 五指山市| 深州市| 商丘市| 濮阳县| 丰城市| 奉新县| 通河县| 塘沽区| 贺兰县| 新巴尔虎右旗| 拉萨市| 张家川| 南投市| 达日县| 甘南县| 大丰市| 甘泉县| 千阳县| 云南省| 纳雍县| 青河县| 大埔区| 多伦县| 工布江达县| 子长县| 永德县| 喀什市| 托克托县| 南木林县| 普安县| 霍山县|