Documentation Home

8.2.1.12 IS NULL 优化

MySQL 可以对其 用于 . 例如,MySQL 可以使用索引和范围来搜索 with 。 col_name IS NULLcol_name = constant_valueNULLIS NULL

例子:

SELECT * FROM tbl_name WHERE key_col IS NULL;

SELECT * FROM tbl_name WHERE key_col <=> NULL;

SELECT * FROM tbl_name
  WHERE key_col=const1 OR key_col=const2 OR key_col IS NULL;

如果WHERE子句包含 声明为 的列的条件,则 该表达式将被优化掉。如果该列无论如何都可能生成(例如,如果它来自 a 右侧的表 ),则不会发生此优化。 col_name IS NULLNOT NULLNULLLEFT JOIN

MySQL 还可以优化 combination ,这是一种在解析子查询中很常见的形式。 显示 何时使用此优化。 col_name = expr OR col_name IS NULLEXPLAINref_or_null

这种优化可以IS NULL针对任何关键部分处理一个。

优化查询的一些示例,假设列ab表上有一个索引t2

SELECT * FROM t1 WHERE t1.a=expr OR t1.a IS NULL;

SELECT * FROM t1, t2 WHERE t1.a=t2.a OR t2.a IS NULL;

SELECT * FROM t1, t2
  WHERE (t1.a=t2.a OR t2.a IS NULL) AND t2.b=t1.b;

SELECT * FROM t1, t2
  WHERE t1.a=t2.a AND (t2.b=t1.b OR t2.b IS NULL);

SELECT * FROM t1, t2
  WHERE (t1.a=t2.a AND t2.a IS NULL AND ...)
  OR (t1.a=t2.a AND t2.a IS NULL AND ...);

ref_or_null通过首先读取引用键,然后单独搜索具有NULL键值的行来工作。

优化只能处理一个IS NULL级别。在以下查询中,MySQL 仅在表达式上使用键查找,(t1.a=t2.a AND t2.a IS NULL)而不能在 上使用键部分 b

SELECT * FROM t1, t2
  WHERE (t1.a=t2.a AND t2.a IS NULL)
  OR (t1.b=t2.b AND t2.b IS NULL);