您的位置:首页 > 数据库 > MySQL

MySQL5.7性能优化系列(二)——SQL语句优化(2)——子查询-派生表-视图--概述

2017-08-02 22:11 393 查看

章节内容:

使用Semi-join连接优化子查询、派生表、视图

使用Materialization优化子查询

优化派生表、视图

使用Exist 策略优化子查询

概述

in或者any子查询

MySQL查询优化器具有不同的策略来评估子查询。对于IN(或= ANY)子查询,优化器具有以下选择:

Semi-join 半连接策略

Materialization物化策略

EXISTS 策略

not in (<>或者all) 子查询

对于NOT IN(或<> ALL)子查询,优化器具有以下选择:

Materialization物化策略

EXISTS 策略

派生表(from 子句中的子查询)

对于派生表(FROM子句中的子查询),优化器具有以下选项:

将派生表合并到外部查询块中

将派生表实现为内部临时表

视图

对于视图,优化器与派生表具有相同的选择。

- 将视图合并到外部查询块中

- 将视图实现为内部临时表

以下讨论提供了有关上述优化策略的更多信息。

注意:

使用子查询修改单个表的UPDATE和DELETE语句的限制,优化器不使用semi-join连接或Materialization子查询优化。作为解决方法,请尝试将其重写为使用连接而不是子查询的多表UPDATE和DELETE语句
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  mysql 性能优化
相关文章推荐