创建索引需要注意什么?

  • 非空字段

        所有的列应指定为 NOT NULL ,除非有存储 NULL 值的需要。因为在 MySQL 中,含有 NULL 值的列很难进行查询优化,会使得索引、索引的统计信息以及比较运算更加复杂,应该用0、一个特殊的字符或者空字符串代替 NULL 值。

ALTER TABLE `table_name` ADD COLUMN `column_name` varchar(10) NOT NULL DEFAULT '' COMMENT 'comment';
  • 索引字段越小越好

        因为数据库的数据存储是以页为单位的。一页存储的数据越多,一次 I/O 读取到数据就越多,那么 读取的效率就会越高。

  • 取值离散大的字段

        因为如果存在大量相同取值的字段,在查询时,结果集的数据行可能占了表中数据很大的比例。所以增加索引,并不能明显加快检索速度。

        可以通过 count() 函数查看字段的差异值,返回值越大说明字段的唯一值越多,字段的离散程度越高。

  • 其他注意事项

  1. 限制表上的索引数目。索引太多会降低性能,因为在对表的更新操作的同时也会维护创建的索引结构并进行更新,索引太多就会导致数据表更新的效率大大下降。
  2. 避免在取值朝一个方向增长的字段(例如:日期类型的字段)上建立索引;对复合索引,避免将这种类型的字段放置在最前面。由于字段的取值总是朝一个方向增长,新记录总是存放在索引的最后一个叶页中,从而不断地引起该页的访问竞争。此外,如果所建索引是聚集索引,表中数据按照索引的排列顺序存放,所有的插入操作都集中在最后一个数据页上进行,从而引起插入“热点”。
  3. 对复合索引,按照字段在查询条件中出现的频度建立索引。在复合索引中,记录首先按照第一个字段排序。对于在第一个字段上取值相同的记录,系统再按照第二个字段的取值排序,以此类推。因此只有复合索引的第一个字段出现在查询条件中,该索引才可能被使用。因此将应用频度高的字段,放置在复合索引的前面,会使系统最大可能地使用此索引,发挥索引的作用。
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值