避免在where子句中使用!=或<>操作符

简介: 避免在where子句中使用!=或<>操作符

1、反例

SELECT * FROM user WHERE salary!=5000

 

SELECT * FROM user WHERE salary<>5000

2、理由

并不是说使用了is null或者 is not null就会不走索引了,这个跟mysql版本以及查询成本都有关;

如果mysql优化器发现,走索引比不走索引成本还要高,就会放弃索引,这些条件 !=,<>,is null,is not null经常被认为让索引失效;

其实是因为一般情况下,查询的成本高,优化器自动放弃索引的;

如果把null值,换成默认值,很多时候让走索引成为可能,同时,表达意思也相对清晰一点;

相关文章
|
6月前
|
存储 编译器
【操作符与关键字】
【操作符与关键字】
56 0
|
22天前
|
SQL
WHERE 子句
【11月更文挑战第02天】
20 1
|
3月前
|
SQL Serverless 数据库
HAVING和WHERE子句 有什么区别?
【8月更文挑战第2天】
125 17
HAVING和WHERE子句 有什么区别?
|
6月前
|
C语言
条件操作符
条件操作符(三目操作符)是C语言中的唯一一个三元运算符,形式为:`表达式1 ? 表达式2 : 表达式3`。如果`表达式1`为真,执行`表达式2`并返回结果;否则执行`表达式3`并返回结果。例子展示了如何用条件操作符输出两个数中的较大值。
33 1
|
5月前
|
SQL 关系型数据库 MySQL
常用的子句和关键字
常用的子句和关键字
|
编译器
详解操作符(下)
详解操作符(下)
|
Linux C++ 索引
操作符详解(二)
操作符详解(二)
90 0
WHERE子句操作符
WHERE子句操作符
38 0