MySQL- 什么时候索引失效?

MySQL- 什么时候索引失效?

1> 最左前缀法则 : 如果是联合索引,查询从索引的最左侧开始,不跳过其他索引. 如果跳过,则索引失效
create index index_name on user(name,status,address);

		select * from user where name = ? and status = ? and address = ?  (全部索引有效)
		
		select * from user where status = ?   (索引失效)
		
		select * from user where name = ? and status = ?   (两个索引有效)
		
		select * from user where name = ? and address = ?  (第一个索引有效, 第二个失效)
		
		select * from user where status = ? and address = ? (索引失效)



2> 使用范围查询时,范围查询条件的右侧的列的索引失效.

select * from user where age > ? and address = ?  则 address 失效.


3> 如果使用运算的话,则索引失效;
	
		select * from user where substring(name,startIndex,count);  name索引失效;
	
	4> 字符串不加单引号则索引失效.
	
		select * from user where id = 1162166234825900032;  id索引失效.
	
	5> 覆盖索引: 只访问索引的查询

		select name,status,address from user;   最优: 因为name,status,address是联合索引, using where;using index;
		select name from user;   				using index;
		select name,fix_name from user;  		using codition;

		using index: 使用覆盖索引的时候就会出现
		using where: 在查找使用索引的情况下,需要回表去查询所需的数据.
		using index condition: 查找使用了索引,但是需要回表查询数据.
		using index;using where : 查找使用了索引,但是需要的数据都在索引列中能找到,所以不需要回表查询数据.

	6> or查询则索引失效.
		
		select * from user where name = ? or nickName = ? 整个索引失效
		
	7> like 模糊查询加前置%则索引失效
	
		select * from user where name like "%xx%";   索引失效, 使用覆盖索引(查询的所有的字段都是索引列)可解决这个问题
	
	8> 如果MYSQL评估使用索引比全表扫描还慢,则MYSQL自动放弃索引查询
	
		select * from user where id = ?  ===> 假设全表共200条数据,扫描到了199条匹配的数据, 则放弃索引,执行全表扫描

	9> is null, is not null 有时索引失效.(由数据值决定)

		select * from user where name is null;   MYSQL会自动评估,如果数据多为null,则索引失效, 如果数据大多数都不null, 则索引有效.
		sekect & from user where name is not null; MYSQL会自动评估,如果数据多不为null,则索引失效, 如果数据大多数都为null, 则索引有效.
											
	10> in , not in     in有效, not in 失效
		
	
	11> 联合索引: 数据库会使用联合索引, 建议使用联合索引
		单列索引: 数据库会使用最优的索引,而不是全部索引.(辨识度最高的优先)

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MySQL 索引可能会失效的情况如下: 1. 表结构变更:对表结构的修改,如删除或更改字段,可能导致索引失效。 2. 数据修改:如果对数据进行大量的修改或插入操作,可能导致索引失效。 3. 过于复杂的查询条件:如果查询中包含过于复杂的条件,MySQL 可能无法使用索引。 4. 索引过大:如果索引非常大,MySQL 可能无法对其进行有效的扫描。 5. 不适当的数据类型:如果使用不适当的数据类型创建索引,可能导致索引无效。 为了确保索引的有效性,建议定期进行表结构和数据的优化。 ### 回答2: MySQL的索引有以下几种情况下可能会失效: 1. 当查询涉及索引列的函数操作时,索引无法被利用。例如,对于以下查询: ```sql SELECT * FROM table WHERE YEAR(column) = 2022; ``` 如果column有索引,由于YEAR函数对列进行操作,索引将无法被使用,导致失效。 2. 当使用LIKE进行模糊查询时,索引可能会失效。如果使用LIKE查询的模式没有以通配符开头(例如'%abc'),索引可以被利用。但是,如果使用通配符开头(例如'abc%'),索引将无法被使用。 3. 当进行OR操作时,如果其中一个条件列有索引,而另一个列没有索引,索引可能会失效。例如,以下查询: ```sql SELECT * FROM table WHERE column1 = 123 OR column2 = 456; ``` 假设column1有索引,column2没有索引,这种情况下索引无法被使用。 4. 当表的数据量非常小的时候,索引可能会失效。在这种情况下,MySQL优化器可能会认为直接扫描整个表比使用索引更高效。 5. 当索引的数据分布不均匀的时候,索引可能会失效。如果索引的值重复度非常高,那么MySQL可能会认为直接扫描整个表比使用索引更高效。 需要注意的是,这只是一些常见的情况,实际情况还会受到MySQL版本、配置和具体查询语句等多种因素的影响。综合考虑这些因素,才能确定索引是否会失效。 ### 回答3: MySQL的索引可能会在以下几种情况下失效: 1. 对索引列进行了函数操作:如果查询语句中对索引列进行了函数操作,例如使用了表达式、进行了类型转换、使用了内置函数等,那么MySQL无法使用该列上的索引进行优化,索引会失效。 2. 对索引列进行了隐式类型转换:如果查询语句中对索引列进行了隐式类型转换,例如将字符串类型的列与数字进行比较,MySQL无法使用该列上的索引进行优化,索引会失效。 3. 对索引列进行了范围查询:当查询语句中对索引列进行了范围查询,例如使用了大于、小于、区间等操作符,MySQL只能使用该列上的索引进行部分优化,而无法完全利用索引,索引的效果会降低。 4. 对索引列进行了模糊查询:如果查询语句中对索引列进行了模糊查询,例如使用了通配符(如%)或正则表达式,MySQL无法使用该列上的索引进行优化,索引会失效。 5. 索引列的基数过低:基数指的是索引列的唯一值的数量,如果索引列的基数太低,那么使用该索引进行优化的效果会减弱,甚至可能导致索引失效。 6. 数据量过大:当表中数据量非常大时,即使有索引也可能导致索引失效。因为MySQL在查询时需要通过索引定位到相应的数据块,如果数据块过大,会增加查询的时间。 因此,在设计数据库和查询语句时,我们需要避免以上情况的发生,以确保索引的有效使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值