【MYSQL系列--优化5】——Is Null 优化
来源:互联网 发布:网络论坛营销方案 编辑:程序博客网 时间:2024/06/06 04:04
MySQL可以对col_name IS NULL执行相同的优化,它可以用于col_name = constant_value。例如,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 OR 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);
阅读全文
0 0
- 【MYSQL系列--优化5】——Is Null 优化
- [MySQL优化案例]系列 — 分页优化
- [MySQL优化案例]系列 — 分页优化
- oracle之 is null 优化
- 8.2.1.8 IS NULL Optimization NULL 优化:
- 8.2.1.8 IS NULL Optimization NULL 优化:
- 【MySQL系列--优化1】——嵌套join优化
- 【MySQL系列--优化3】——多范围读取优化
- [MySQL优化案例]系列 — slave延迟很大优化方法
- [MySQL优化案例]系列 — slave延迟很大优化方法
- MySQL系列—特定类型查询优化
- MySQL系列—慢查询优化案例
- Linux is not Matrix——mysql优化脚本
- mysql 性能优化系列
- mysql系列:数据库优化
- MySql的优化系列
- Android优化系列——代码优化
- Android性能优化系列—布局优化
- 关于521
- 引用类型和指针
- 用Navicat连接数据库详解
- python读取xml文件
- django setting概述
- 【MYSQL系列--优化5】——Is Null 优化
- leetcode
- Android零基础入门第25节:简单且最常用的LinearLayout线性布局
- linux下的后台处理
- vue:一群java后台死在配置上
- MySQL5.7性能优化系列(二)——SQL语句优化(2)——使用 Semi-Join半连接变换优化子查询,派生表和视图
- ssm批量删除和模糊查询
- Linux C线程总结(1)
- Java基础概念