网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.分区的情况下,对insert速度影响.
.Oracle Database 10g:最佳新特性.
.Linux备份策略研究.
.Oracle 10g Installer 创建临时文.
.oracle 分析函数的使用.
.Oracle产品服务和技术级别的介绍.
.Oracle 10g中SCN与TimeStamp的斗.
.ORACLE8i在Penitum4/WINDOWS机器.
.Oracle中的Merge函数(批量更新/删.
.jb+oracle+weblogic cmp中使用自.
.数据库系统紧急故障处理方法.
.回滚段问题.
.Database 10g:忘掉我以前的功能.
.精妙SQL语句介绍.
.Oracle数据库备份与恢复精华资料.
.Oracle DBA 创建数据库试题选.
.使用PL/SQL关联数组访问元素.
.PL/SQL DEVELOPER 基本用法详解.
.在T-SQL中实现Oracle的MINUS集合.
.Linux环境下oracle9i的Dataguard.

新的最优化参数缩短反应时间

发表日期:2008-2-9



  在Oracle9i之前,仅有的两个CBO模式是ALL_ROWS以及FIRST_ROWS。传统的FIRST_ROWS SQL最优化的缺点之一是,它的运算法则并没有非凡指定行检索的范围。
  但是,在Oracle9i中包含了几个新的最优化指令:
  FIRST_ROWS_1
  FIRST_ROWS_10
  FIRST_ROWS_100
  FIRST_ROWS_1000
  FIRST_ROWS_n最优化会指示选择一个查询执行计划,这个计划会缩短生成最初n行查询结果的时间。
  你可以把这个新的CBO模式设置到数据库中的几个层次上:systemwide,在会话层或者在查询层次上。
  alter system set optimizer_mode=first_rows_100;
  alter session set optimizer_mode = first_rows_100;
  select /*+ first_rows(100) */ from student;
  根据来自Oracle公司的说法,使用FIRST_ROWS_n最优化,Oracle查询能够使用最少的反应时间来给出最初的n行结果。更快速的给出最初n行的结果能够提高用户对应用软件的满足程度的原因是由于用户能够更为快速的得到最初的那些数据。
  当使用FIRST_ROWS最优化索引的时候,ALL_ROWS最优化支持完整表的搜寻。但是,Oracle通过FIRST_ROWS_n最优化扩展了这个概念的范畴。
  在传统的FIRST_ROWS最优化中,Oracle CBO支持索引扫描,甚至当全部成本高于完整表扫描的时候也是如此。在对于完整表扫描不太昂贵的较小型表的情况下,这种情况也是尤为明显。
  请看一看下面的这个例子。
  Set autotrace on eXPlain
  alter session set optimizer_goal = choose;
  select * from emp where sal < 1200;
  PLAN -----------------------------------------------------
  SELECT STATEMENT (OPTIMIZER=CHOOSE) (COST=62) (ROWS=99)
  TABLE Access FULL EMP (COST=62) (ROWS=99)
  现在,我们要使用FIRST_ROWS最优化来进行相同的查询工作。
  alter session set optimizer_goal = first_rows;
  select * from emp where sal < 1200;
  The explain plan is now transformed to:
  PLAN -----------------------------------------------------
  SELECT STATEMENT (OPTIMIZER=FIRST_ROWS) (COST=102)
  TABLE ACCESS BY INDEX ROWID EMP (COST=102) (ROWS=99)
  INDEX RANGE SCAN SA L_IDX (COST=2) (ROWS=99)
  我们希望CBO能够对索引进行支持,但是我们还是非常惊异的看到选择了一种比完整表扫描更为昂贵的方式。这是一个临界点。在Oracle9i之前,FIRST_ROWS最优化是一种对内部规则和费用的一种综合,而且Oracle9i FIRST_ROWS最优化也是完全基于成本的。
  在Oracle9i之前,我们使用OPTIMIZER_INDEX_COST_ADJ参数来控制CBO选择索引。
  虽然Oracle公司声称FIRST_ROWS_n最优化能够让查询变得更加快速,但是要记住, Oracle9i CBO所负责的是最初那些行的查询访问的成本。换一种说法,所有的FIRST_ROWS_n模式所做的就是决定出更为明智的选择,决定是使用索引还是使用完整表扫描来进行对小型表的访问。由于多数的Oracle9i DBA会把这些小型表存储于KEEP池中,因此该参数使用的范围并不广。
上一篇:CERN应用Oracle9iAS提高网络应用性能 人气:580
下一篇:如何用变量传递表名实现删除表的操作 人气:692
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐