mysql索引原则

1.in

		当in()中的数据很大时,不走索引
		
		当查询的列是char类型没有加引号,mysql优化器会自动给填充引号,同时也会导致索引失效
		
		当in()中存在子查询、格式化函数等同样也会使索引失效!

2.blob和text字段仅支持前缀索引.
3. 使用!=以及<>不等于的时候,mysql不使用索引.
4. 当在字段时候函数的时候,mysql无法使用索引;
5. 在join时条件字段类型不一致的时候,mysql无法使用索引;
6. 在组合索引里使用非第一个索引时也不使用索引.
7. 在使用like的时候,以%开头,即"%***"的时候无法使用索引;在使用or的时候,要求or前后字段都有索引.

MySQL索引创建时应遵循一些基本原则,以提高查询性能并优化数据库结构: 1. **选择恰当的字段**:对经常用于WHERE、JOIN或ORDER BY语句的列创建索引。这些列的数据变化频率相对较低且值的唯一性越高越好。 2. **避免过宽的索引**:如果索引包含过多的列,查询效率会降低,因为每次搜索都需要比较所有列。尽量创建复合索引(如 `(column1, column2)`),当需要同时过滤多个列时。 3. **考虑覆盖索引**:如果一个查询的返回结果可以由索引完全提供,那么就不需要访问数据表了,这称为“覆盖索引”。例如,对于`SELECT column1, column2 FROM table WHERE column1 = ?`,如果`column1`和`column2`都在索引内,就形成了覆盖索引。 4. **避免在频繁更新的列上创建索引**:因为插入、删除或修改操作会使索引失效,可能导致性能下降。但对于读取密集型应用,这通常是可以接受的。 5. **分区和索引配合**:对于大表,可以考虑按某个列进行分区,然后在每个分区上单独创建索引。 6. **避免全表扫描**:理想情况下,索引应该使得大部分查询能够快速定位到特定行,而不是导致全表扫描。 7. **注意哈希索引**:哈希索引只适用于等值查找,而且不能处理排序,所以在涉及范围查询时效果不佳。 8. **定期维护**:通过ANALYZE TABLE或OPTIMIZE TABLE命令检查和调整索引,保持其有效性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值