MySQL 中的 NOT 逻辑运算符

MySQL 中的 NOT 逻辑运算符

NOT 是 MySQL 的 逻辑运算符,用于对布尔值取反,通常用于 WHERE 子句中,与其他逻辑条件结合使用


1. NOT 的基本用法

NOT 用于否定一个条件,常见的形式有:

SELECT * FROM users WHERE NOT age = 18;

等价于

SELECT * FROM users WHERE age <> 18;

解释

  • 查询 age 不是 18 的用户。
  • NOT 作用在 age = 18 之上,使其取反

2. NOTIS NULL

在 MySQL 中,判断 NULL 值不能使用 =,必须用 IS NULLNOT 也适用于 IS NULL

SELECT * FROM users WHERE NOT name IS NULL;

等价于

SELECT * FROM users WHERE name IS NOT NULL;

解释

  • NOT name IS NULL 表示 name 不为 NULL

3. NOTLIKE

用于字符串匹配的取反

SELECT * FROM users WHERE NOT name LIKE 'A%';

等价于

SELECT * FROM users WHERE name NOT LIKE 'A%';

解释

  • NOT name LIKE 'A%' 代表查找名字不以 ‘A’ 开头的用户。

4. NOTIN

NOT 也可用于 IN,表示不属于某个集合

SELECT * FROM users WHERE NOT age IN (18, 20, 22);

等价于

SELECT * FROM users WHERE age NOT IN (18, 20, 22);

解释

  • NOT age IN (18, 20, 22) 表示 age 不等于 18、20 或 22

5. NOTBETWEEN

NOT 可用于 BETWEEN,表示不在某个范围内

SELECT * FROM users WHERE NOT age BETWEEN 18 AND 25;

等价于

SELECT * FROM users WHERE age < 18 OR age > 25;

解释

  • 查找年龄不在 18 到 25 之间的用户。

6. NOTEXISTS

NOT EXISTS 用于子查询,表示当子查询结果为空时返回 TRUE

SELECT * FROM users u WHERE NOT EXISTS (
    SELECT 1 FROM orders o WHERE o.user_id = u.id
);

解释

  • 查找没有下过订单的用户

7. NOT 影响 NULL

NOT 遇到 NULL 时,结果可能变成 UNKNOWN(不确定),因为:

  • NULL 代表未知值,NOT NULL = 1 仍然是 NULL

示例

SELECT NOT NULL;

结果NULL

示例

SELECT * FROM users WHERE NOT age = NULL;

不会返回任何结果,因为 NULL 不能用 = 比较。

解决方案:使用 IS NOT NULL

SELECT * FROM users WHERE age IS NOT NULL;

8. NOTANDOR 结合

NOT 可以和 ANDOR 组合使用:

SELECT * FROM users WHERE NOT (age = 18 OR city = 'New York');

等价于

SELECT * FROM users WHERE age <> 18 AND city <> 'New York';

解释

  • NOT (A OR B) 等价于 NOT A AND NOT B德摩根定律)。
  • NOT (A AND B) 等价于 NOT A OR NOT B

9. 总结

语法作用说明
NOT condition取反NOT (age = 18)age <> 18
NOT IS NULL判断非空NOT name IS NULLname IS NOT NULL
NOT LIKE模糊匹配取反NOT name LIKE 'A%' → 名字不以 ‘A’ 开头
NOT IN集合取反NOT age IN (18, 20, 22)age 不是 18/20/22
NOT BETWEEN范围取反NOT age BETWEEN 18 AND 25age < 18 OR age > 25
NOT EXISTS子查询取反NOT EXISTS (子查询) → 子查询为空时返回 TRUE

✅ 重点

  1. NOT 主要用于取反逻辑,但要小心 NULL 影响。
  2. 避免 NOT 直接作用于索引列,可能导致索引失效(如 NOT age = 18)。
  3. NOTANDOR 结合时,遵循 德摩根定律 进行逻辑转换。

如果查询性能受影响,可以考虑优化查询方式,如 索引优化、避免 NOT 作用于索引列!🚀

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BirdMan98

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值