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

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

1、反例

1. SELECT * FROM user WHERE salary!=5000
2. 
3. SELECT * FROM user WHERE salary<>5000

2、理由

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

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

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

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


目录
相关文章
|
7月前
|
C++
83 C++ - 谓词
83 C++ - 谓词
20 0
|
8月前
|
存储 索引
【操作符】
【操作符】
25 0
|
11天前
|
SQL 关系型数据库 MySQL
常用的子句和关键字
常用的子句和关键字
|
1月前
|
C语言
条件操作符
条件操作符(三目操作符)是C语言中的唯一一个三元运算符,形式为:`表达式1 ? 表达式2 : 表达式3`。如果`表达式1`为真,执行`表达式2`并返回结果;否则执行`表达式3`并返回结果。例子展示了如何用条件操作符输出两个数中的较大值。
19 1
|
10月前
|
编译器 C语言 索引
S5——C操作符详解,你都知道吗? 下
讲解主要内容: 1. 各种操作符的介绍 2. 表达式求值 以下让我们开始正式重新认识和理解操作符吧!
|
10月前
|
存储 编译器 C语言
7.27C语言知识点之操作符
7.27C语言知识点之操作符
44 0
|
11月前
|
存储 数据安全/隐私保护
操作符详解(1)
操作符详解(1)
|
关系型数据库 MySQL 索引
避免在where子句中使用!=或<>操作符
避免在where子句中使用!=或<>操作符
WHERE子句操作符
WHERE子句操作符
26 0