sql语句中where后边的哪些条件会使索引失效 -- SQL语句优化

时间:2022-06-10 03:05:53

在我们编写sql的过程中where的条件使用不当会使索引(index)失效

1. 在 where 子句中使用!=或<>操作符,会使引擎放弃使用索引而进行全表扫描

2. 在 where 子句中对字段进行 null 值判断,会使引擎放弃使用索引而进行全表扫描

sql语句中where后边的哪些条件会使索引失效 -- SQL语句优化

3. 在 where 子句中使用 or 来连接条件,会使引擎放弃使用索引而进行全表扫描

sql语句中where后边的哪些条件会使索引失效 -- SQL语句优化

可改为:

sql语句中where后边的哪些条件会使索引失效 -- SQL语句优化

 4. 在 where 子句中对字段进行表达式操作,会使引擎放弃使用索引而进行全表扫描

sql语句中where后边的哪些条件会使索引失效 -- SQL语句优化

可改为:

sql语句中where后边的哪些条件会使索引失效 -- SQL语句优化

5. 在where子句中对字段进行函数操作,会使引擎放弃使用索引而进行全表扫描

sql语句中where后边的哪些条件会使索引失效 -- SQL语句优化

6. 在 where 子句中的“=”左边进行函数、算术运算或其他表达式运算,系统将可能无法正确使用索引