论坛登陆 注册 教程 笑话 影视 投稿
首页 | 页界资讯 | 网络应用 | 软件应用 | 组网技术 | 网络原理 | 聊天通讯 | 网管知识 | 帮助
笑话 | 操作系统 | 注 册 表 | 编程开发 | 数 据 库 | 媒体动画 | 网页设计 | 图形图象 | 地图
论坛 | 网络安全 | 安全防范 | 服 务 器 | 硬件学堂 | 路由技术 | 搜索研究 | 站长经验 | 投稿
影院 | 教育频道 | 特色专题 | 精文荟萃 | 注 册 码 | 论坛社区 | 网站地图 | 广告服务 | 旧版
设为首页 加入收藏
当前位置:首页>>文章>>数据库>>Oracle>>正文

使用智能优化器提高Oracle的性能极限

www.xker.com 作者: 来源:net130 加入日期:2006-2-28 10:06:13

【问题提问、论坛交流】

使用智能优化器提高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_limitoptimizer_max_permutations的默认值是80,000

  参数optimizer_search_limit和optimizer_max_permutations一起来确定优化器所考虑的组合数目的上限:除非(表或组合数目)超过参数optimizer_search_limit 或者 optimizer_max_permutations设定的值,否则优化器将生成所有可能的连接组合一旦优化器停止评估表的连接组合,它将选择成本最低的组合

本新闻共3页,当前在第1页  1  2  3  

编辑:xker.com

上一篇:Oracle数据库游标使用大全
下一篇:没有了
关闭窗口】【技术交流】【收藏此页
相关文章
·Oracle数据库游标使用大全·Oracle9i中监视索引的使用·使用Oracle实现实时通信
·Oracle SQL 内置函数大全·Oracle实用技巧
推荐文章 最新文章 热门文章
·毕业论文范文
·毕业论文格式
·计算机毕业论文
·用VC获取本机IP地址列表的方法
·用KC 短信免费发 电话免费打
·Windows 2003服务器安全配置终极技巧
·巧用“隐身”浏览器与你老板打游击
·迁移临时文件夹 让系统性能全面提升
·轻松找回遗忘的网站论坛帐号密码
·SQLServer和Access、Excel数据传输简
·分析网页的几种加密技术
·读懂Windows“虚拟内存”问题
·ASP中调用存储过程、语法、写法-sql
·深入浅出VC++串口编程之DOS的串口编程
·ADSL Modem设置含义及功能全知道(四)
·使用智能优化器提高Oracle的性能极限
·察看FreeBSD日志信息
·FreeBSD下gd库的安装方法
·FreeBSD在安装ports时缩短下载时间
·配置Intel® i810显示芯片组在Fre
·FREEBSD升级及优化全攻略
·千千静听下载
·毕业论文范文
·毕业论文格式
·计算机毕业论文
·拒绝共享 保护自己电脑文件的安全
·QQ空间皮肤代码
·免费午餐 将图片放到国外免费空间上
·Css不朽的经典—3D文字特效
·别出心裁 巧妙使用输入法制作特殊字符
·个人简历表格
·免费代理IP(每日更新)
·QQ密码丢失后能做的事情:快速找回密码
·Norton AntiVirus 2006 注册码(激活
·豪杰超级解霸V9.1正版注册码
·WinRAR 3.51 注册码
·系统优化 专题
·找回QQ密码的注意事项 
·史上最强QQ个人档案资料欣赏
·Ajax技术开发指南
·最经典的黑客入门教材
·求职简历封皮
·ACDSee v8.0注册码
·怎样查找对方的IP地址
·应届毕业生求职信
评论

设为首页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyright © 2003-2006 xker.com All rights reserved.小新技术网 合作广告QQ:12231446
本页浏览次数: