解析Oracle 8i/9i的计划稳定性
2006-08-05 11:58:19 来源:WEB开发网update outln.ol$hints
set ol_name =
decode(
ol_name,
'SO_FIX','SYS_OUTLINE_020503165427311',
'SYS_OUTLINE_020503165427311','SO_FIX'
)
where ol_name in ('SYS_OUTLINE_020503165427311','SO_FIX')
;
对于这样做,你可能感到有点不习惯,特别是根据指南上的建议--不过这个更新在Metalink(译者注:这是Oracle的一个技术支持站点)上是允许的。不过,你还需要做第二次更新来确保和每个存储概要相联系的hints数目保持一致。如果你忽略了这一步,你将会发现你的一些存储概要被损坏,或者在一个导出/导入中的处理中被破坏。
update outln.ol$ ol1
set hintcount = (
select hintcount
from ol$ ol2
where ol2.ol_name in ('SYS_OUTLINE_020503165427311',' SO_FIX')
and ol2.ol_name != ol1.ol_name
)
where
ol1.ol_name in ('SYS_OUTLINE_020503165427311','SO_FIX')
;
一旦完成上面的语句,你就可以发起一个新的连接,告诉它使用存储概要,重新运行该过程然后退出;同样地,你可以使用sql_trace来确认Oracle确实是这样做的。要告诉Oracle使用修改后的存储概要,你可以使用以下的命令:
alter session set use_stored_outline = demo;
检查trace文件,你将会发现该SQL现在使用and_equal的路径(如果你使用tkprof来处理和解释trace文件,你将会发现输出显示了两个矛盾的路径。第一个将展示使用的and_equal路径,第二个将可能是一个全表搜索,这是因为在tkprof在跟踪的SQL上执行explain plan时,该存储概要可能没有被调用)。
- ››oracle 中 UPDATE nowait 的使用方法
- ››Oracle ORA-12560解决方法
- ››Oracle 10g RAC 常用维护命令
- ››Oracle如何在ASM中定位文件的分布
- ››Oracle的DBMS_RANDOM.STRING 的用法
- ››oracle 外部表导入时间日期类型数据,多字段导入
- ››Oracle中查找重复记录
- ››oracle修改用户登录密码
- ››Oracle创建删除用户、角色、表空间、导入导出等命...
- ››Oracle中登陆时报ORA-28000: the account is lock...
- ››Oracle数据库在配置文件中更改最大连接数
- ››Oracle中在pl/sql developer修改表的两种方式
更多精彩
赞助商链接