MySql创建索引的技巧
1、高维度的列创建索引(维度是数据列中不重复的值出现的个数,这个数量越高维度就越高);
2、尽量对on、where、group by、order by中出现的列使用索引;
3、对较小的数据列使用索引,这样会使索引文件更小,从而使内存中可以装载更多的索引键;
4、未较长的字符串使用前缀索引
有时候需要索引很长的字符列,这会让索引变得大且慢。通常可以索引开始的部分字符,这样可以大大节约索引空间,从而提高索引效率。但这样也会降低索引的选择性。索引的选择性是指不重复的索引值(也称为基数,cardinality)和数据表的记录总数的比值,范围从1/#T到1之间。索引的选择性越高则查询效率越高,因为选择性高的索引可以让MySQL在查找时过滤掉更多的行。唯一索引的选择性是1,这是最好的索引选择性,性能也是最好的。
一般情况下某个前缀的选择性也是足够高的,足以满足查询性能。对于BLOB,TEXT,或者很长的VARCHAR类型的列,必须使用前缀索引,因为MySQL不允许索引这些列的完整长度。
诀窍在于要选择足够长的前缀以保证较高的选择性,同时又不能太长(以便节约空间)。前缀应该足够长,以使得前缀索引的选择性接近于索引的整个列。换句话说,前缀的”基数“应该接近于完整的列的”基数“。
为了决定前缀的合适长度,需要找到最常见的值的列表,然后和最常见的前缀列表进行比较
5、不要过多创建索引,除了要增加额外的磁盘开销,对于DML操作的速度影响也很大,因为每次增删改都要更新索引;
6、使用组合索引,可以减少文件索引大小,在运行时速度要优于单列索引。