暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

[ACDU 翻译] 8.2.1.15 IS NULL优化

原创 由迪 2021-04-08
311

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还可以优化组合 ,这种形式在已解决的子查询中很常见。 显示 何时使用此优化。 col_name = expr OR col_name IS NULLEXPLAINref_or_null

此优化可以处理IS NULL任何关键部分。

假设在列a和 b表上都有索引,则对查询进行一些优化的示例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);

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论