MySQL查询优化之九-IS NULL优化(IS NULL Optimization)

MySQL查询优化之九-IS NULL优化(IS NULL Optimization)


如需转载请标明出处:http://blog.csdn.net/itas109
QQ技术交流群:129518033

环境:
MySQL版本:5.5.15
操作系统:windows

本文讨论IS NULL优化(IS NULL Optimization)。

MySQL可以对col_name = constant_value使用col_name IS NULL来执行相同的优化。 例如,MySQL可以使用索引和范围来用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 NULL的列包含col_name IS NULL条件,则会优化该表达式。 这种优化不会发生在列可能产生NULL的情况下; 例如,如果它来自LEFT JOIN右侧的表格。

MySQL还可以优化组合col_name = expr或col_name IS NULL,这是解析子查询中常见的一种形式。 当使用此优化时,EXPLAIN显示ref_or_null。

此优化可以处理任何关键部件的一个IS NULL。

假设在表t2的列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仅对表达式(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);

Reference:
https://dev.mysql.com/doc/refman/5.5/en/is-null-optimization.html


觉得文章对你有帮助,可以用微信扫描二维码捐赠给博主,谢谢!
微信
如需转载请标明出处:http://blog.csdn.net/itas109
QQ技术交流群:129518033

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

itas109

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

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

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

打赏作者

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

抵扣说明:

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

余额充值