- 浏览: 1020192 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (529)
- 服务器 (8)
- jsp (1)
- java (6)
- AIX (1)
- solaris (3)
- linux学习 (53)
- javaScript (2)
- hibernate (1)
- 数据库 (74)
- sql语句 (8)
- oracle 学习 (75)
- oracle 案例 (42)
- oracle 管理 (42)
- Oracle RAC (27)
- oracle data guard (12)
- oracle 参数讲解 (14)
- Oracle 字符集 (8)
- oracle性能调优 (24)
- oracle备份与恢复 (12)
- oracle Tablespace (9)
- oracle性能诊断艺术 (1)
- oracle 11g学习 (5)
- oracle streams (1)
- oracle upgrade and downgrade (4)
- db2学习 (13)
- db2命令学习 (2)
- mysql (28)
- sql server (30)
- sql server 2008 (0)
- 工具 (10)
- 操作系统 (3)
- c++ (1)
- stock (1)
- 生活 (5)
- HADOOP (2)
最新评论
-
massjcy:
...
如何将ubuntu文件夹中文名改为英文 -
skypiea:
谢谢。。。
终于解决了。。。
Oracle 10.2.0.4(5)EM不能启动的解决方案(Patch 8350262) -
qwe_rt:
引用vi /etc/sysconfig/network 请问 ...
Linux操作系统下配置静态IP上网 -
liuqiang:
sudo killall -9 apache2
ps 和 kill 命令详解 -
dazuiba:
引用*绝杀 kill -9 PID 当使用此命令时,一定要通过 ...
ps 和 kill 命令详解
消耗在准备利用Oracle执行计划机制提高查询性能新的SQL语句的时间是Oracle SQL语句执行时间的最重要的组成部分。但是通过理解Oracle内部产生执行计划的机制,你能够控制Oracle花费在评估连接顺序的时间数量,并且能在大体上提高查询性能。
准备执行SQL语句
当SQL语句进入Oracle的库缓存后,在该语句准备执行之前,将执行下列步骤:
1) 语法检查:检查SQL语句拼写是否正确和词序。
2) 语义分析:核实所有的与数据字典不一致的表和列的名字。
3) 轮廓存储检查:检查数据字典,以确定该SQL语句的轮廓是否已经存在。
4) 生成执行计划:使用基于成本的优化规则和数据字典中的统计表来决定最佳执行计划。
5) 建立二进制代码:基于执行计划,Oracle生成二进制执行代码。
一旦为执行准备好了SQL语句,以后的执行将很快发生,因为Oracle认可同一个SQL语句,并且重用那些语句的执行。然而,对于生成特殊的SQL语句,或嵌入了文字变量的SQL语句的系统,SQL执行计划的生成时间就很重要了,并且前一个执行计划通常不能够被重用。对那些连接了很多表的查询,Oracle需要花费大量的时间来检测连接这些表的适当顺序。
评估表的连接顺序
在SQL语句的准备过程中,花费最多的步骤是生成执行计划,特别是处理有多个表连接的查询。当Oracle评估表的连接顺序时,它必须考虑到表之间所有可能的连接。例如:六个表的之间连接有720(6的阶乘,或6 * 5 * 4 * 3 * 2 * 1 = 720)种可能的连接线路。当一个查询中含有超过10个表的连接时,排列的问题将变得更为显著。对于15个表之间的连接,需要评估的可能查询排列将超过1万亿(准确的数字是1,307,674,368,000)种。
使用optimizer_search_limit参数来设定限制
通过使用optimizer_search_limit参数,你能够指定被优化器用来评估的最大的连接组合数量。使用这个参数,我们将能够防止优化器消耗不定数量的时间来评估所有可能的连接组合。如果在查询中表的数目小于optimizer_search_limit的值,优化器将检查所有可能的连接组合。
例如:有五个表连接的查询将有120(5! = 5 * 4 * 3 * 2 * 1 = 120)种可能的连接组合,因此如果optimizer_search_limit等于5(默认值),则优化器将评估所有的120种可能。optimizer_search_limit参数也控制着调用带星号的连接提示的阀值。当查询中的表的数目比optimizer_search_limit小时,带星号的提示将被优先考虑。
另一个工具:参数optimizer_max_permutations
初始化参数optimizer_max_permutations定义了优化器所考虑组合数目的上限,且依赖于初始参数optimizer_search_limit。optimizer_max_permutations的默认值是80,000。
参数optimizer_search_limit和optimizer_max_permutations一起来确定优化器所考虑的组合数目的上限:除非(表或组合数目)超过参数optimizer_search_limit 或者 optimizer_max_permutations设定的值,否则优化器将生成所有可能的连接组合。一旦优化器停止评估表的连接组合,它将选择成本最低的组合。
使用ordered提示指定连接顺序
你能够设定优化器所执行的评估数目的上限。但是即使采用有很高价值的排列评估,我们仍然拥有使优化器可以尽早地放弃复杂的查询的重要机会。回想一下含有15个连接查询的例子,它将有超过1万亿种的连接组合。如果优化器在评估了80,000个组合后停止,那么它才仅仅评估了0.000006%的可能组合,而且或许还没有为这个巨大的查询找到最佳的连接顺序。
在Oracle SQL中解决此问题的最好的方法是手工指定表的连接顺序。为了尽快创建最小的解决方案集,这里所遵循的规则是将表结合起来,通常优先使用限制最严格的WHERE子句来连接表。
下面的代码是一个查询执行计划的例子,该例子在emp表的关联查询上强制执行了嵌套的循环连接。注意,我已经使用了ordered提示来直接最优化表的评估顺序,最终它们表现在WHERE子句上。
|
这个例子要求优化器按顺序连接在SQL语句的FROM子句中指定的表,在FROM子句中的第一个表指定了驱动表。ordered提示通常被用来与其它的提示联合起来来保证采用正确的顺序连接多个表。它的用途更多的是在扭转连接表数在四个以上的数据仓库的查询方面。
另外一个例子,下面的查询使用ordered提示按照指定的顺序来连接表:emp、dept、sal,最后是bonus。我通过指定emp到dept使用哈希连接和sal到bonus使用嵌套循环连接,来进一步精炼执行计划。
|
实践建议
实际上,更有效率的做法是在产品环境中减小optimizer_max_permutations参数的大小,并且总是使用稳定的优化计划或存储轮廓来防止出现耗时的含有大量连接的查询。一旦找到最佳的连接顺序,您就可以通过增加ordered提示到当前的查询中,并保存它的存储轮廓,来为这些表手工指定连接顺序,从而使其持久化。
当你打算使用优化器来稳定计划,则可以照下面的方法使执行计划持久化,临时将optimizer_search_limit设置为查询中的表的数目,从而允许优化器考虑所有可能的连接顺序。然后,通过重新编排WHERE子句中表的名字,并使用ordered提示,与存储轮廓一起使变更持久化,来调整查询。在查询中包含四个以上的表时,ordered提示和存储轮廓将排除耗时的评估SQL连接顺序解析的任务,从而提高查询的速度。
一旦检测到最佳的连接顺序,我们就可以使用ordered提示来重载optimizer_search_limit和optimizer_max_permutations参数。ordered提示要求表按照它们出现在FROM子句中的顺序进行连接,所以优化器没有加入描述。
作为一个Oracle专业人员,你应该知道在SQL语句第一次进入库缓存时可能存在重大的启动延迟。但是聪明的Oracle DBA和开发人员能够改变表的搜索限制参数或者使用ordered提示来手工指定表的连接顺序,从而显著地减少优化和执行新查询所需的时间。
发表评论
-
enq: TX - row lock contention
2011-02-25 16:24 2391Article by Rampant Author Brian ... -
Oracle 9i在AIX上的性能调整 -- 内存篇
2011-01-19 23:29 1190内存访问的冲突出现在当进程申请的内存超过系统的物理内存总量时, ... -
包含IN子查询的SQL语句的优化
2010-12-09 11:10 6808当SQL语句中包含in语句时,有时候会极大的影响性能,我们可 ... -
Oracle中优化SQL语句执行的原则
2010-12-03 15:12 12751。已经检验的语句和已在共享池中的语句之间要完全一 ... -
详述逻辑读
2010-12-01 11:13 1274这篇实验讨论下数据的读写过程. 我们都知道,数据块是o ... -
相关重做的等待事件
2010-12-01 11:07 902晶晶实验十二 相关重 ... -
深度分析数据库的热点块问题(latch: cache buffers chains)
2010-11-28 07:35 4571热点块的定义 数据库 ... -
oracle 常见等待事件及处理方法
2009-12-10 17:39 1580我们可以通过视图v$session_wait来查看系统当前的等 ... -
Oracle常见等待事件介绍
2009-12-10 17:36 1265Oracle的等待事件是衡量Oracle运行状况的重要依据 ... -
Oracle隐藏索引和索引可用性
2009-09-03 10:16 1044在我参与过的许多商店系统开发中,我发现在生产系统中创建一个索引 ... -
ORACLE SQL性能优化 (下)
2009-08-20 16:38 103931. 强制索引失效如果两个或以上索引具有相同的等级,你可以强 ... -
Oracle性能调整与优化(二)
2009-07-26 23:48 1131为了能取得圆满成功,我将涉及到一些预备步骤,它们将在查看发生了 ... -
Oracle性能调整与优化一
2009-07-26 23:30 1107Oracle性能调整是一个范围比较广且有点复杂的主题,普通DB ... -
Oracle数据库设计提升性能的五条法则
2009-07-26 23:12 1060众所周知,数据库设计的好坏直接关系到数据库运行的效率。根据笔者 ... -
Oracle性能调整的要点之SGA
2009-07-26 23:09 1089一、Shared pool tunning Shared p ... -
不要让临时表空间影响数据库性能
2009-07-21 16:49 1142在Oracle数据库中进行排 ... -
关于SGA设置的一点总结
2009-07-16 23:05 999本总结不针对特例,仅对服务器只存在OS + ORACLE 为例 ... -
如何优化数据库的性能
2009-07-16 22:49 22311、 硬件调整性能 最 ... -
oracle性能优化心得
2009-07-12 22:19 1284很多的时侯, 做Oracle DBA的我们,当应用治理员向我 ... -
分析数据库性能的SQL
2009-07-12 22:10 1008--用于查看哪些实例的哪些操作使用了大量的临时段 SELEC ...
相关推荐
掌握执行计划的分析,可以帮助我们更好地理解SQL执行的底层机制,从而优化查询,提高数据库系统的整体性能。对于开发人员和DBA来说,这是必不可少的技能,因为它直接影响到应用程序的响应时间和资源消耗。通过深入...
智能优化的核心在于利用数据库的内置机制,如成本基础优化(Cost-Based Optimizer, CBO)和智能搜索限制(Optimizer Search Limit),来自动调整和优化SQL执行计划,从而提高查询效率。 #### 2. 成本基础优化(CBO) ...
优化包括多个层面,首先是查询语句的编写,好的查询语句应当尽量利用Oracle的优化器来减少不必要的数据处理。例如,合理使用索引、避免全表扫描、使用绑定变量等。其次是SQL语句的结构调整,例如通过重写SQL语句来...
标题中的“提高数据库性能,提高Oracle数据库性能,PCIe FLASH”涉及到的是数据库优化与...通过深入理解Oracle数据库的运行机制,并利用各种工具,我们可以有效地提高数据库的运行效率,确保系统的稳定性和响应速度。
### 充分利用Oracle8并行处理能力提高系统性能 #### Oracle8并行性简介 在当前的信息处理系统中,特别是在决策支持系统(DSS)和在线分析处理(OLAP)工具等领域,往往需要处理非常庞大的数据库。面对海量数据处理...
1. **Oracle Wait Interface (OWI)**:OWI是Oracle 9i引入的一个新特性,它提供了一种机制,使得数据库能够报告正在等待什么,从而帮助DBA更准确地定位性能问题。OWI通过等待事件来收集数据库的运行情况,等待事件是...
如果找到匹配的语句,那么可以直接使用已有的执行计划,避免重新从硬盘读取数据,从而提高查询速度。这是Oracle数据库性能优化的一个重要策略,即利用共享池(Shared Pool)来缓存执行计划,实现快速响应。 如果在...
默认的优化器是CHOOSE,但推荐在具备准确统计信息的情况下使用COST,因为CBO能更精确地估算执行计划的成本,从而提高查询性能。为此,定期运行ANALYZE命令更新对象统计信息至关重要。 其次,Oracle访问表的方式主要...
### Oracle查询性能优化知识点详解 #### 一、注意WHERE子句中的连接顺序 **原则一:** ORACLE在解析WHERE子句时采用自下而上的顺序。为了提高查询效率,应确保表之间的连接条件写在其他WHERE条件之前,并且应该将...
在IT领域,尤其是在数据库管理与优化方面,Oracle数据库因其强大的功能和广泛的用途...通过对资源消耗、执行计划和常见执行计划类型的深入了解,数据库管理员可以采取有效措施,优化查询性能,确保系统的高效稳定运行。
通过以上内容的介绍,我们可以看到Oracle数据库机制涉及到了多个方面,包括重做日志的管理和利用、归档模式的选择、实例恢复机制以及权限与角色的管理等。这些机制共同作用,确保了Oracle数据库的高度可靠性和安全性...
根据提供的文件信息,“ORACLE DATABASE 11G性能优化攻略_高清...同时,利用Oracle 11g提供的性能监控工具可以帮助快速定位并解决性能问题。希望这些知识点能够帮助读者更好地理解和掌握Oracle 11g性能优化的相关技术。
### Oracle性能优化技巧详解 ...理解并合理配置优化模式、选择合适的表扫描策略以及充分利用SQL重用机制等都是提升Oracle性能的关键步骤。希望本文能帮助读者更好地理解和掌握Oracle性能优化的核心技巧。
书中可能涵盖Oracle的查询优化器工作原理,如成本基优化器和统计信息的收集,以及如何通过EXPLAIN PLAN分析查询执行计划,找出性能瓶颈。优化器的选择策略、 Hint的使用以及CBO(Cost-Based Optimizer)的参数调整也...
5. **缓存机制**:利用Oracle的缓冲区缓存机制,将常用数据保留在内存中,减少磁盘访问次数。 6. **并行查询**:在高配置服务器上启用并行查询,可以让多个进程同时执行查询的不同部分,提高整体处理能力。 ### ...
这提高了执行效率,但也意味着多表连接查询可能无法利用这一优化,因为它们涉及的表结构和连接条件可能导致不同的执行计划。 4. **高速缓冲(Cache Buffering)**:Oracle对简单表的查询结果进行高速缓存,但这不...
查询优化是性能优化的核心,Oracle数据库通过查询优化器(Query Optimizer)来选择执行SQL语句的最佳计划。优化器会基于统计信息和成本估算来决定表的扫描方式、连接顺序和操作顺序。了解如何阅读和理解执行计划,...
- **低效的SQL语句**:查询设计不合理或未充分利用Oracle的功能。 - **整体架构设计缺陷**:如不当的数据分布或过度集中处理等。 #### 四、性能问题定位 性能问题的定位通常遵循以下步骤: - **SQL级别**:首先检查...