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

章节内容:

  • 使用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语句

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值