Documentation Home
MySQL 8.4 Reference Manual
Related Documentation Download this Manual
PDF (US Ltr) - 39.8Mb
PDF (A4) - 39.9Mb
Man Pages (TGZ) - 257.9Kb
Man Pages (Zip) - 364.9Kb
Info (Gzip) - 4.0Mb
Info (Zip) - 4.0Mb


10.2.1.15 IS NULL 优化

MySQL 可以对col_名IS NULL进行相同的优化,它可以使用索引和范围来搜索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 子句包含一个对列声明为NOT NULLcol_名IS NULL条件,那么该表达式将被优化 away。这一优化在列可能产生NULL的情况下不发生(例如,如果它来自左侧的LEFT JOIN)。

MySQL 也可以优化组合col_名 = expr OR col_名 IS NULL,这是常见的解决子查询形式。EXPLAIN 显示ref_或_null当这个优化被使用时。

这优化可以处理任何键部分的一个IS NULL

以下是一些假设表 t2 中有索引在列 ab 的查询优化示例:

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);