Query Transformation 查询变换 (Page 61)
Prior to the development of the execution plan, a step called query transformation occurs.
This step
happens just after a query is checked for syntax and permissions and just before the optimizer computes
cost estimates for the various plan operations it considers when determining the final execution plan. In
other words, transformation and optimization are two different tasks.
在生成执行计划之前,有一步称之为“查询变换”的步骤将发生。
这一步紧接着查询的语法和权限被检查之后,且在优化器计算成本,评估它所考虑的各种计划操作,确定最终执行计划之前执行。换句话说,变换和优化是两个不同的任务。
After your query passes the syntactical and permissions checks, the query enters the transform
phase in a set of query blocks. A query block is defined by the keyword SELECT. For example, select
*
from employees where department_id = 60 has a single query block.
However, select * from employees where department_id in (select
department_id from departments) has two query blocks. Each query block is either nested within another or interrelated to another in some way. The way the query is written determines the relationships between query blocks. It is the query transformer’s main objective to determine if changing the way the query is written will provide a better query plan.
在你的查询通过语法和权限检查之后,查询进入一组查询块集的变换阶段。一查询块被关键字SELECT所定义。例如select *
from employees where department_id = 60有一个单独的查询块。然而,select * from
employees where department_id in (select department_id from departments)
有两个查询块。每个查询块要么嵌入另一个之中或者以某种方式关联到其他块中。书写查询的方式确定了查询块之间的关系。查询变换的主要目的是确定是否改变所写的查询方式将生成更佳的查询计划。
Make sure you caught that last sentence. The query transformer can, and will, rewrite your query.
This is something you may have never realized. What you write may not end up being the exact
statement for which the execution plan is developed.
Many times this is a good thing. The query
transformer knows how the optimizer deals with certain syntax and will do everything it can to render
your SQL in a way that helps the optimizer to come up with the best, most efficient execution plan.
However, the fact that what you write can be changed may mean that a behavior you expected,
particularly the order in which certain parts of the statement occur, doesn’t happen the way you
intended. Therefore, you really need to understand how query transformation works so that you can
make sure to write your SQL properly to get the behaviors you intend.
务必关注上面的语句。查询变换器能够,也会,重写你的查询。可能你从来没有意识到。你所写的(语句)可能最终不是开发执行计划时(所参考)的准确语句。
很多时候这是件好事。查询变换知道优化器如何处理某些语法,然后尽一切可能渲染(加工)你的SQL,帮助优化器生成最佳最有效的执行计划。然而,事实上可能改变你书写的(语句),意味着你所期望的行为,特别是某些部分的语句的执行顺序,不是按照你的意图发生的。因此,你真正需要理解查询变换如何工作的,以至于你能确保以适当的方式书写你的SQL取得期望的行为。
The query transformer may change the way you originally formulated your query as long as the
change does not affect the result set. Any change that might cause the result set to differ from the
original query syntax will not be considered. The change that is most often made is to transform
separate query blocks into straight joins. For example, this statement
select * from employees where department_id in (select department_id from departments)
will likely be transformed into this statement
select e.* from employees e, departments d where e.department_id = d.department_id
The result set doesn’t change, but the execution plan choices for the transformed version would be
better from the optimizer’s point of view.
查询变换可能改变最初你书写查询的方式,只要改变不影响结果集。任何可能导致结果集不同于最初的查询语法的改变将不被考虑。最常用的改变是变换分散的查询块成直接的连接。例如,语句
select * from employees where department_id in (select department_id from departments)
将可能被变换成语句
select e.* from employees e, departments d where e.department_id = d.department_id
结果集没有改变,但是从优化器的观点来看执行计划选择变换版本(的语句)将更好。
Once you learn what to look for, you can usually tell by looking at the execution plan if a
transformation occurs. You can also execute your query using the NO_QUERY_TRANSFORMATION hint and compare the execution plan from this query with the plan from the query without the hint.
If the two
plans are not the same, the differences can be attributed to query transformation.
When using the hint,
all query transformations with the exception of predicate pushing (which I’ll review shortly) will be
prohibited.
一旦你知道了要查找什么,你就能通过查询执行计划知道是否发生了查询变换。你也可以用NO_QUERY_TRANSFORMATION提示执行你的查询然后将执行计划与不带提示的查询的执行计划相比较。如果两个计划不相同,不同点可归咎于查询变换。
当使用了提示,所有除“谓词
推进
”(我等会讲解)
之外的查询变换将被禁止。
There are several basic transformations that can be applied to a given query:
-
View merging
-
Subquery unnesting
-
Predicate pushing
-
Query rewrite with materialized views
有如下几种基本的变换可以应用于给定的查询:
-
视图合并
-
子查询反嵌套
-
谓词推进
-
用物化视图重写查询
分享到:
相关推荐
cmd脚本-bat批处理-RUN.zip
内容概要:本文详细介绍了 MySQL 中的数据类型,将其分为数值、日期/时间和字符串三大类。数值类型涵盖从 TINYINT 到 BIGINT 的整数类型以及浮点数和 DECIMAL 类型,每种类型都有明确的存储大小和取值范围。日期/时间类型包括 DATE、TIME、YEAR、DATETIME 和 TIMESTAMP,适用于不同的日期和时间表达需求,其中 TIMESTAMP 具有自动更新特性。字符串类型则由 CHAR、VARCHAR、BLOB、TEXT、ENUM 和 SET 组成,能够存储固定长度或可变长度的字符及二进制数据。此外,还提及了空间数据类型,如 GEOMETRY 等,用于存储地理信息和几何图形数据。; 适合人群:数据库管理员、软件开发者及其他需要深入了解 MySQL 数据库设计与优化的专业人士。; 使用场景及目标:①为数据库设计提供理论依据,确保选择合适的数据类型以优化性能;②帮助开发者理解各种数据类型的特性和应用场景,以便更好地进行应用程序开发。; 其他说明:正确选择 MySQL 数据类型对于提高数据库效率至关重要,应根据实际需求合理选用不同类型。例如,在存储大量文本时,应考虑使用 TEXT 或 BLOB 类型;对于需要精确计算的数值,则优先选用 DECIMAL 类型。同时,了解每种类型的特点有助于避免潜在的数据丢失或溢出风险。
cmd脚本-bat批处理-去掉字符串头所有的0.zip
cmd脚本-bat批处理-全盘禁止运行指定程序.zip
cmd-bat-批处理-脚本-语音参考字典.zip
内容概要:本文档《Docker 新手入门指南》详细介绍Docker这一开源容器化平台,旨在帮助新手理解并掌握Docker的核心概念和基本操作。文中首先解释了Docker的概念及其相对于传统虚拟机的优势,如更快的启动速度、更低的资源占用和更好的隔离性。接着,文档提供了详细的安装步骤,包括不同操作系统下的安装方法以及针对国内用户的镜像加速配置。随后,文章深入讲解了镜像管理和容器操作的基础命令,如拉取镜像、运行容器等。进一步地,文档介绍了使用Dockerfile构建自定义镜像、实现数据持久化、进行端口映射以及利用Docker Compose管理多容器应用等高级技巧。最后,给出了一些学习建议和注意事项,鼓励读者动手实验并关注安全性。 适合人群:适合对容器技术感兴趣的初学者,尤其是有一定Linux基础或打算深入了解Docker的开发人员。 使用场景及目标:①帮助读者快速上手Docker,掌握从安装到实际操作的一系列技能;②通过实例演示,如构建Python Web服务、部署WordPress和搭建Jenkins环境,让读者能够将所学应用于实际项目中;③强调容器化的优势,如提高部署效率、解决环境差异问题。 阅读建议:建议读者跟随文档逐步操作,亲身体验每个步骤,同时参考官方文档和社区资源,不断实践以巩固所学知识。特别注意安全性和资源管理方面的提示,确保容器环境的安全稳定运行。
cmd-bat-批处理-脚本-九宫格图案.zip
据QYResearch调研团队最新报告“全球斗式提升机链条市场报告2024-2030”显示,预计2030年全球斗式提升机链条市场规模将达到1亿美元,未来几年年复合增长率CAGR为4.4%。 市场驱动因素: 散装物料输送行业的增长:水泥、采矿、农业和发电等行业的需求不断增长,推动了斗式提升机在垂直物料运输中的应用。基础设施建设和工业化:全球建筑活动的不断增长和工业厂房的扩张推动了对重型输送系统的需求。链式系统的效率和耐用性:链式斗式提升机因其强度高、使用寿命长而成为重型和高温应用的首选。自动化和工厂优化:采用自动化和智能控制系统可提高链式输送机的性能和运行效率。 市场制约因素: 初始安装和维护成本高:与基于皮带的替代方案相比,链式系统更昂贵且更复杂,尤其对于小型作业而言。恶劣环境下的磨损:如果不进行适当的维护,持续暴露于磨蚀性或腐蚀性材料中会导致更快的老化。某些设施的空间限制:斗式提升机的垂直设计和占地面积可能并不适合所有场地布局,从而限制了其适用性。 市场机遇: 链条材料的技术进步:耐磨耐腐蚀合金和涂层的开发延长了产品的使用寿命和可靠性。农业和食品加工行业的扩张:新兴市场对谷物处理、化肥运输和散装食品转运的需求不断增长,推动了链条的使用。现有系统的改造和升级:有机会用高性能链条系统替换过时的机械部件,以提高产量。对节能输送解决方案的需求不断增长:对降低能耗的重视推动了链传动系统和铲斗设计的创新。 根据QYResearch头部企业研究中心调研,全球范围内斗式提升机链条生产商主要包括Tsubakimoto Chain、Renold、Thiele、Pewag、RUD Ketten、HEKO Group、John King Chains、B.V.Transmission Industries、Transmin、华通气动等。2024年,全球前五大厂商占有大约51.0%的市场份额。 就
cmd脚本-bat批处理-删除指定路径下指定文件及文件夹外的所有文件及文件夹1.zip
内容概要:本文由麦肯锡发布,探讨了人工智能(AI)特别是生成式AI(gen AI)如何重塑组织架构及创造价值。研究表明,企业正在通过重新设计工作流程、提升治理水平和应对更多与gen AI相关的风险来捕捉AI的价值。CEO对AI治理的监督与工作流的重新设计是取得财务影响的关键因素。大公司正引领这一变革,它们更积极地招聘AI相关人才并进行员工再培训。此外,企业正逐步采用AI于多个业务职能,包括营销、销售、产品开发和服务运营。尽管目前大部分公司尚未看到AI对企业整体利润的显著影响,但已有迹象表明,AI的应用正在增加收入并减少成本。 适合人群:企业高管、AI项目经理、战略规划人员以及对AI技术应用感兴趣的商业人士。 使用场景及目标:①帮助企业管理层理解如何通过AI技术优化内部流程并提高效率;②为AI项目的实施提供参考,确保企业在部署AI时能够最大化其商业价值;③指导企业在风险管理、人才招聘和员工技能升级方面做出明智决策。 其他说明:随着AI技术的发展,企业需要不断调整自身结构和流程以适应新技术带来的变化。文中提到的最佳实践如建立专门团队推动AI采用、定期沟通AI价值、高层领导积极参与等做法,可以为企业成功引入AI提供有益借鉴。此外,文中还强调了AI对不同行业的影响差异,以及个人使用AI工具的趋势变化。
内容概要:本文主要介绍了SQL注入的概念、危害及其防范措施。SQL注入是攻击者通过恶意构造输入,使服务器执行非预期的SQL命令的一种攻击方式,常因用户输入未
cmd脚本-bat批处理-查看工作组.zip
cmd-bat-批处理-脚本-不显示输入密码.zip
Gauss-Seidel迭代,OpenMP并行化本质上是不行的,输入文件
cmd-bat-批处理-脚本-IE不能打开新链接修复.zip
cmd-bat-批处理-脚本-批处理加密.zip
以下是一个基于蒙特卡罗法的可靠性分析Matlab程序代码,该代码能够处理具有任意分布的随机变量,并且可以考虑多个失效模式。代码中包含了测试案例,可以直接在Matlab软件中运行。同时,代码中附有详细注释,便于理解。 该程序基于蒙特卡罗法进行可靠性分析,适用于处理具有任意分布的随机变量以及多个失效模式。 用户可以通过修改random_vars和random_params来定义随机变量的分布类型和参数,通过修改failure_modes来定义失效模式函数。 程序中包含一个测试案例,可以直接在Matlab软件中运行,以验证程序的正确性。 程序代码中附有详细注释,便于用户理解和修改。
cmd-bat-批处理-脚本-断开网络联结.zip
内容概要:本文详细介绍了三种删除 MySQL 数据库的方法:使用 SQL 语句 drop 命令、使用 mysqladmin 命令行工具以及使用 PHP 脚本。drop 命令可以直接删除指定数据库,带有 IF EXISTS 选项可以防止因数据库不存在而报错。mysqladmin 工具提供了一种交互式的删除方式,增强了安全性。PHP 脚本则展示了如何通过编程语言与 MySQL 进行交互,完成数据库的删除操作。文中强调了删除数据库前应确保有足够权限,并提醒操作不可逆,建议先备份。 适合人群:具有基础 MySQL 操作知识的数据库管理员、开发者及运维人员。 使用场景及目标:①了解并掌握多种删除 MySQL 数据库的方式;②提高对数据库管理的安全意识,避免误删重要数据;③学会在不同环境下选择合适的工具进行数据库维护。 阅读建议:由于删除数据库是一项高风险操作,在实际应用中务必谨慎行事。建议读者先在一个测试环境中练习本文提到的各种方法,熟悉每一步骤后再应用于生产环境。同时,对于 PHP 脚本部分,需要具备一定的编程基础。