8.2.1.13 IS NULL 优化
MySQL 可以对* col_name
* IS NULL执行与col_name
* =
* constant_value
*相同的优化。例如,MySQL 可以使用索引和范围使用IS NULL搜索NULL
。
Examples:
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 NULL
的列的* col_name
* IS NULL条件,则该 table 达式将被优化。在该列无论如何都会产生NULL
的情况下(例如,如果它来自LEFT JOIN
右侧的 table),则不会进行此优化。
MySQL 还可以优化组合col_name = expr OR col_name IS NULL
,这种形式在已解析的子查询中很常见。使用此优化时,EXPLAIN显示ref_or_null。
此优化可以为任何关键部分处理一个IS NULL。
假设在 tablet2
的列a
和b
上有索引,则对查询进行一些优化的示例:
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 仅在 table 达式(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);