今天听课说,关于绑定变量,在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》是Oracle 9i数据库系统性能优化的重要教程,主要针对OCP(Oracle Certified Professional)考试的培训内容。Oracle 9i是Oracle数据库的一个关键版本,它引入了许多性能优化特性和技术,以提升...
1. **SQL优化**:SQL语句是数据库操作的核心,优化SQL性能对于整体系统性能至关重要。这包括使用绑定变量、避免全表扫描、合理使用索引、减少表连接和子查询的复杂性等策略。 2. **物理存储结构优化**:包括表空间...
它提供了一个深入洞察SQL语句执行细节的窗口,包括绑定变量、执行计划、执行时间等。 2. **启用10046事件跟踪** 要开始跟踪,首先需要获取与应用程序连接的Oracle会话的SPID(进程ID)、SID(会话ID)和SERIAL#。...
在本例中,减小`large_pool_size`以扩大`shared_pool_size`是一种临时解决方案,但长期应优化SQL语句,特别是那些未绑定变量的语句,以及处理DDL操作引发的对象失效。 未绑定变量的SQL语句是引发硬解析和`ORA-04031...
- **SQL优化**:使用`EXPLAIN PLAN`分析查询计划,通过索引、物化视图和绑定变量提升查询效率。 - **性能监控**:利用`V$视图`监控数据库性能,如CPU使用率、I/O延迟等。 - **调优工具**:学习使用Oracle的性能...
10. **性能优化**:通过分析SQL语句的执行计划,调整索引、分区策略,使用绑定变量,以及利用数据库调优顾问(DBMS_ADVISOR)来提升系统性能。 11. **安全性**:理解权限和角色的管理,以及如何设置用户权限,限制...
其他性能优化手段包括索引建立、分区、绑定变量使用、SQL调优顾问等。 八、安全性控制 Oracle9i提供了严格的权限和角色管理,确保数据安全。通过GRANT和REVOKE命令授予和撤销权限,角色则是一组权限的集合。审计...
这涉及到SQL语句的优化,如使用索引、物化视图、绑定变量等方法提升查询效率。另外,我们还需要关注系统的资源利用率,如CPU、内存和磁盘I/O,通过调整初始化参数、分区技术、并行执行策略等手段来提高整体性能。 ...
- 对于动态SQL语句,确保所有需要的变量都已正确赋值。 #### 四、搜索与定位错误 - **Oracle 文档查询**:Oracle官方文档是获取详细错误信息的第一选择。可以访问Oracle官方网站或使用Oracle提供的文档工具来查询...
Oracle 9i支持标准SQL语句,如SELECT、INSERT、UPDATE、DELETE,以及更复杂的子查询、联接和视图操作。学习者应熟练掌握SQL语法,并能运用到实际的数据库操作中。 四、数据库对象管理 数据库中的对象包括表、索引、...
6. 性能优化:通过分析SQL语句执行计划、调整索引、使用绑定变量、调整初始化参数等手段,可以提升数据库性能。理解如何使用Oracle的性能分析工具如 tkprof 和 Explain Plan 非常关键。 7. 高可用性与故障恢复:...
此外,索引、分区技术和绑定变量也是提高查询性能的关键。 五、备份与恢复 Oracle9i支持多种备份策略,如完整备份、增量备份和归档日志备份。在恢复过程中,RMAN(Recovery Manager)工具是主要的恢复管理工具,...
9. **性能优化**:通过分析SQL执行计划、调整索引、使用绑定变量、分区技术等方法,可以提高Oracle数据库的运行效率。 10. **PL/SQL编程**:Oracle的PL/SQL是一种过程化语言,用于编写存储过程、函数、触发器等...
性能优化涉及到查询优化、索引策略、内存管理、SQL语句调整以及数据库架构的设计。通过理解执行计划、使用EXPLAIN PLAN、分析统计信息,以及应用绑定变量等方法,可以显著提升数据库的响应速度。 5. **ORACLE ...
- **绑定变量**:用于传递动态值到SQL语句中,可以提高性能和安全性。 - **固定执行计划**:通过HINTS或SQL Profile。 - **调整排序内存**:通过SORT_AREA_SIZE参数调整。 - **临时表空间**:用于存储临时数据,如...
- 或者配置数据库实例来自动跟踪SQL语句,通常通过`_sql_trace_in_error`参数设置。 6. **SQL调整最关注的是什么** - 执行效率(如响应时间和资源消耗)。 - 查询计划的优化,确保使用最合适的索引和表连接顺序...