【SQL优化器】初始化参数

一些和优化器相关的初始化参数 
 1、 OPTIMIZER_FEATURES_ENABLE 
 每个版本的Oracle 优化器特性都不相同,特别是做了版本升级以后一定要修改这个参数才可以使用仅被该版本支持的优化器特性。 
 可以赋予它的值如:9.2.0、9.0.2、9.0.1、8.1.7、8.1.6 等。 
 2、 CURSOR_SHARING 
 这个参数会将SQL 语句中的常量用变量来替换,存在大量常量的OLTP 系统可以考虑启用这个参数。但是有一点要明白,绑定变量虽然可以使大量的SQL 重用,减少分析时间,但是当数据分布发生变化后,CBO 为绑定变量SQL 生成的执行计划可能不是最优(不会考虑具体的变量值)。通常OLTP 系统适用于绑定变量,OLTP 系统特点是,SQL 运行频繁且时间相对较短,SQL 的分析时间比重较大。如果在DSS 系统中,SQL 运行时间长,相比之下分析时间微不足道,好的执行计划才是最重要的,因此DSS 系统绑定变量要另行考虑。 
 3、 HASH_AREA_SIZE 
 这是散列连接时散列表的存放区域,如果使用散列连接这个参数值不能过小,如果散列表不能完全存放于内存中,对散列连接性能的影响很大。如果是9i 建议启动工作区自动管理,然后设置PGA_AGGREGATE_TARGET。 
 4、 SORT_AREA_SIZE 
 内存排序区的大小,如果排序时内存区不够会写如磁盘。9i 同样建议启动工作区自动管理,然后设置PGA_AGGREGATE_TARGET。 
 5、 HASH_JOIN_ENABLED 
 如果启用这个参数,CBO 在考虑连接方法的时候将会考虑散列连接。 
6、 OPTIMIZER_INDEX_CACHING 
 这个参数表示被缓存的索引块所占百分比,可选值的范围是0-100。这个值会影响嵌套循环连接,如果这个值设得较高,CBO 将更倾向使用嵌套循环。 
 7、 OPTIMIZER_INDEX_COST_ADJ 
 优化器利用这个参数(是个百分比)把索引扫描的成本转换为等价的全表扫描的成本,然后与全表扫描的成本进行比较。缺省值100,表示索引扫描成本与全表扫描成本等价。可选值范围是0-10000。 
 8、 OPTIMIZER_MAX_PERMUTATIONS 
 这个初始参数用来设定优化器最多考虑多少种连接顺序,优化器不断的产生可能的表的连接的排列,直到排列数达到参数optimizer_max_permutations 为止。一旦优化器停止产生新的可能连接排列,它将会从中选择出成本最小的排列。 
 9、 DB_FILE_MULTIBLOCK_READ_COUNT 
 这个参数表示在全表扫描或索引快速全扫描时一次I/O 读的连续数据块数量(block#连续,且一次I/O 不能超过extent)。 
 10、 OPTIMIZER_MODE 
 优化器模式,也是优化器的优化目标。值为:RULE、CHOOSE、ALL_ROWS、FIRST_ROWS_n、FIRST_ROWS。 
 11、 PARTITION_VIEW_ENABLED 
 如果设置为TRUE, 该优化器将跳过分区视图中未被请求的分区,该参数还能更改基于成本的优化程序从基础表统计信息计算分区视图统计信息的方式。 
 12、 QUERY_REWRITE_ENABLE 
 如果设置为TRUE,优化器将利用可用的物化视图来重写SQL。 
     

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22664653/viewspace-673058/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/22664653/viewspace-673058/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值