mysql is null优化_如何优化mysql的is null?

给大家安利下MySQL的最新手册,就是如何优化mysql的is null?包括如果编写mysql is null的语句。

1b0cca659bc4fac64867bf7f4cb137aa.png

《MySQL使用手册》第二章主要讲述了优化程序如何处理WHERE子句,例子中使用了SELECT语句,但是在DELETE和UPDATE语句中对WHERE子句的优化是一样的。本节讲的是MySQL如何优化ISNULL。

MySQL如何优化IS NULL

MySQL在col_nameISNULL时做和col_name=constant_value一样的优化。例如,MySQL使用索引或者范围来根据ISNULL搜索NULL。

41fd86686a7c901a94c94158b360df82.png

如果一个WHERE子句包括了一个col_name IS NULL条件,并且这个字段声明为NOTNULL,那么这个表达式就会被优化。当字段可能无论如何都会产生NULL值时,就不会再做优化了;例如,当它来自一个LEFTJOIN中右边的一个表时。

MySQL4.1.1或更高会对连接col_name=exprANDcol_nameISNULL做额外的优化,常见的就是子查询。EXPLAIN当优化起作用时会显示ref_or_null。

优化程序会为任何索引部分处理IS NULL。

以下几个例子中都做优化了,假使字段a和表t2中b有索引了:

6ba4e6248f05f1df59b9b1734809ec9f.png

ref_or_null首先读取引用键,然后独立扫描键值为NULL的记录。

请注意,优化程序只会处理一个ISNULL级别。下面的查询中,MySQL只会使用键来查询表达式(t1.a=t2.aANDt2.aISNULL)而无法使在b上使用索引部分:

225a8c82e815988a21148020377843a0.png

以上就是我们今天所讲的优化mysql的is null,大家学会了么?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值