`

ORA 9i SQL语句绑定变量-优化

阅读更多

今天听课说,关于绑定变量,在9i前需要app,如果在9i后,如果app已经烂到根拉,从来没有用过绑定变量,那么还可以用这个参数,用了这个参数,就会把所有的sql都变成绑定变量的拉。。。太牛了吧。不行,我的测试一下...

 

游标共享
设置参数 CURSOR_SHARING=FORCE或CURSOR_SHARING=SIMILAR,
可把SQL语句的字面值转换成绑定变量,减少解析SQL的时间

 

Oracle9i里一个令人激动的内部新特性是,它允许SQL基于代价的优化器(cost-based optimizer,CBO)改变执行计划,即使正在使用优化器计划的稳定性。这叫做“窥视(peeking)”,当绑定变量导致SQL的执行计划发生重大改变的时候,它允许SQL的CBO更该执行计划。

但是,指针共享在优化的时候有一个处理延迟,只有当应用程序生成动态SQL的时候,或者它在必须嵌入文字值的应用程序里的时候,它才应该被使用。由于绑定变量的缘故,PL/SQL应用程序不会从指针共享里获益。

为了说明这一问题,你可以考虑以下这样一个例子:我们的CURSOR_SHARING参数被设置为FORCE。这会把所有的SQL文字值都改为库缓冲区里的主变量(host variable)。

现在,让我们假设我们有了一个对客户(customer)表格的区域(region)列的索引。区域列有四个值:东(east)、南(south)、西(west)、北(north)。区域列的数据值高度不对称,90%的值都在南部地区。

所以在指定南部的时候,让SQL的CBO来执行完整的表格扫描,而在指定东、西、北的时候,使用索引范围扫描,这样速度会更快。在使用指针共享的时候,SQL的CBO会把SQL里的任何文字值都改为绑定变量。所以这个陈述式可以改成下面这样:

select
   customer_stuff
from
   customer
where
   region = 'west';

这个转换会把文字west替换成主变量:

select
   customer_stuff
from
   customer
where
   region = ':var1';

在Oracle9i里,SQL的CBO会在第一次调用指针的时候,“窥视”由用户定义的绑定变量的值。这就能够让优化器确定WHERE子句操作符的选择性,并在south值每次出现在SQL的时候更改执行计划。

当绑定变量用于高度不对称的数据列时,这就极大地提高了指针共享的性能。在Oracle9i里,我们看到了一个用于CURSOR_SHARING的新设置,叫做SIMILAR。

有了CURSOR_SHARING=SIMILAR,Oracle会切换到绑定变量,如果这样做不会导致结果产生任何变化的话,但是如果使用绑定变量会造成结果的巨大变化,它就会使用文字值。

stop!
有Bug



把参数cursor_sharing=exact 该为cursor_sharing=force后会极大的提高非共享的动态sql语句的执行性能。(oracle自动通过变量绑定实现)

如:
select * from heat_handle where order = 1;
select * from heat_handle where order = 2;
oracle认为这两句是一样的,可以重用。

首先oracle 把select * from heat_handle where order = 1;
改为select * from heat_handle where order = :"SYS_B0";
然后用select * from heat_handle where order = :"SYS_B0";的执行计划来
执行select * from heat_handle where order = 2;


由此引起的问题:
把参数cursor_sharing=exact 该为cursor_sharing=force后
下面的语句
SELECT RGSTJ_13.worker,
(FLOOR(SUM(RGSTJ_13.T_TIME1)/60) + MOD(SUM(RGSTJ_13.T_TIME1),60)/100)
FROM WELDPR.RGSTJ_13
group by RGSTJ_13.worker;
执行后:在库缓存中的sql语句是
SELECT worker,
((FLOOR(SUM(RGSTJ_13.T_TIME1)/:"SYS_B_0")
+
MOD(SUM(RGSTJ_13.T_TIME1),:"SYS_B_1")/:"SYS_B_2"))
FROM WELDPR.RGSTJ_13
group by RGSTJ_13.worker;

当在次执行
SELECT RGSTJ_13.worker,
(FLOOR(SUM(RGSTJ_13.T_TIME1)/60) + MOD(SUM(RGSTJ_13.T_TIME1),60)/100)
FROM WELDPR.RGSTJ_13
group by RGSTJ_13.worker;
语句时提示错误
ORA-01006 bind variable not exits
因为已经把原来的sql语句中的60,60,100用:"SYS_B_0",:"SYS_B_1",:"SYS_B_2"绑定变量给替换了,所以报错了。

摘自:http://laojinjian.spaces.live.com/blog/

分享到:
评论

相关推荐

    ora9i性能调整2

    《ora9i性能调整2》是Oracle 9i数据库系统性能优化的重要教程,主要针对OCP(Oracle Certified Professional)考试的培训内容。Oracle 9i是Oracle数据库的一个关键版本,它引入了许多性能优化特性和技术,以提升...

    ora9i性能调整

    1. **SQL优化**:SQL语句是数据库操作的核心,优化SQL性能对于整体系统性能至关重要。这包括使用绑定变量、避免全表扫描、合理使用索引、减少表连接和子查询的复杂性等策略。 2. **物理存储结构优化**:包括表空间...

    oracle的10046事件跟踪.pdf

    它提供了一个深入洞察SQL语句执行细节的窗口,包括绑定变量、执行计划、执行时间等。 2. **启用10046事件跟踪** 要开始跟踪,首先需要获取与应用程序连接的Oracle会话的SPID(进程ID)、SID(会话ID)和SERIAL#。...

    oracle 圆桌会议交流文档 性能相关

    在本例中,减小`large_pool_size`以扩大`shared_pool_size`是一种临时解决方案,但长期应优化SQL语句,特别是那些未绑定变量的语句,以及处理DDL操作引发的对象失效。 未绑定变量的SQL语句是引发硬解析和`ORA-04031...

    操作 Oracle 9i 数据库

    - **SQL优化**:使用`EXPLAIN PLAN`分析查询计划,通过索引、物化视图和绑定变量提升查询效率。 - **性能监控**:利用`V$视图`监控数据库性能,如CPU使用率、I/O延迟等。 - **调优工具**:学习使用Oracle的性能...

    oracle 9i 英文课件

    10. **性能优化**:通过分析SQL语句的执行计划,调整索引、分区策略,使用绑定变量,以及利用数据库调优顾问(DBMS_ADVISOR)来提升系统性能。 11. **安全性**:理解权限和角色的管理,以及如何设置用户权限,限制...

    oracle9i 实物讲座

    其他性能优化手段包括索引建立、分区、绑定变量使用、SQL调优顾问等。 八、安全性控制 Oracle9i提供了严格的权限和角色管理,确保数据安全。通过GRANT和REVOKE命令授予和撤销权限,角色则是一组权限的集合。审计...

    Oracle 9i for Linux数据库管理

    这涉及到SQL语句的优化,如使用索引、物化视图、绑定变量等方法提升查询效率。另外,我们还需要关注系统的资源利用率,如CPU、内存和磁盘I/O,通过调整初始化参数、分区技术、并行执行策略等手段来提高整体性能。 ...

    oracle error message

    - 对于动态SQL语句,确保所有需要的变量都已正确赋值。 #### 四、搜索与定位错误 - **Oracle 文档查询**:Oracle官方文档是获取详细错误信息的第一选择。可以访问Oracle官方网站或使用Oracle提供的文档工具来查询...

    Oracle 9i数据库技术的基础培训教程

    Oracle 9i支持标准SQL语句,如SELECT、INSERT、UPDATE、DELETE,以及更复杂的子查询、联接和视图操作。学习者应熟练掌握SQL语法,并能运用到实际的数据库操作中。 四、数据库对象管理 数据库中的对象包括表、索引、...

    oracle9i资料库管理实物讲座

    6. 性能优化:通过分析SQL语句执行计划、调整索引、使用绑定变量、调整初始化参数等手段,可以提升数据库性能。理解如何使用Oracle的性能分析工具如 tkprof 和 Explain Plan 非常关键。 7. 高可用性与故障恢复:...

    Oracle9i 数据库管理基础

    此外,索引、分区技术和绑定变量也是提高查询性能的关键。 五、备份与恢复 Oracle9i支持多种备份策略,如完整备份、增量备份和归档日志备份。在恢复过程中,RMAN(Recovery Manager)工具是主要的恢复管理工具,...

    Oracle9i基础

    9. **性能优化**:通过分析SQL执行计划、调整索引、使用绑定变量、分区技术等方法,可以提高Oracle数据库的运行效率。 10. **PL/SQL编程**:Oracle的PL/SQL是一种过程化语言,用于编写存储过程、函数、触发器等...

    Oracle速查手册HandBood系列(By FengGe整理)

    性能优化涉及到查询优化、索引策略、内存管理、SQL语句调整以及数据库架构的设计。通过理解执行计划、使用EXPLAIN PLAN、分析统计信息,以及应用绑定变量等方法,可以显著提升数据库的响应速度。 5. **ORACLE ...

    ORACLE DBA面试题集

    - **绑定变量**:用于传递动态值到SQL语句中,可以提高性能和安全性。 - **固定执行计划**:通过HINTS或SQL Profile。 - **调整排序内存**:通过SORT_AREA_SIZE参数调整。 - **临时表空间**:用于存储临时数据,如...

    阿里巴巴公司DBA笔试题

    - 或者配置数据库实例来自动跟踪SQL语句,通常通过`_sql_trace_in_error`参数设置。 6. **SQL调整最关注的是什么** - 执行效率(如响应时间和资源消耗)。 - 查询计划的优化,确保使用最合适的索引和表连接顺序...

Global site tag (gtag.js) - Google Analytics