Oracle数据库的常见问题答疑之集锦(1)

文章作者 100test 发表时间 2007:03:14 13:57:14
来源 100Test.Com百考试题网


Oracle数据库以其强大的功能和稳定性而著称,但同时,在开发和管理方面也存在很多困难,笔者在此总结了一些Oracle数据库开发和管理的常见问题,希望能对大家有所帮助。

问:如果发现表中有坏块,如何检索其它未坏的数据?

答:首先需要找到坏块的ID(可以运行dbverify实现),假设为1234。运行下面的查询查找段名:





0select segment_name, segment_type, block_id, blocks 

from dba_extents 

where (1234 between block_id and (block_id   blocks - 1));

一旦找到坏段名称,若段是一个表,则最好建立一个临时表,存放好的数据。若段是索引,则删除它,再重建。

create table good_table 

as 

0select  from bad_table where rowid not in 

( 0select / index(bad_table, any_index)/ rowid 

from bad_table where substr( rowid, 1, 8 ) = 1234)

问:如请问如何关闭FORM调用REPORT时的小窗口?

答:在利用Oracle数据库的Develop 2000设计开发界面的过程中,当FORM调用REPORT时,会显示一个背景窗口REPORT BACKGROUD ENGINE,等待FORM对REPORT的调用,当FORM调用其它REPORT时,也使用这个后台服务器,不论调用多少个REPORT,这个后台服务器存在且只有一个。但当FORM与REPORT全部退出后,该窗口仍处于等待状态,不会关闭,这时,我们需要手工将其关闭。

我们可以使用以下参数在FORM调用REPORT时不显示这个小窗口:

Add_Parameter( pl_id, ORACLE_SHUTDOWN,TEXT_Parameter, Yes ).

需要注意的是,该参数必须加在所有参数的前面,即它必须为第一个参数。

问:请问如何根据查询条件在REPORT中动态显示记录?

答:1. 在REPORT的“数据模型”下面的“用户参数”中,创建用户自定义参数W_CLAUSE,W_CLAUSE为从FORM传递过来的查询条件,数据类型为字符型,缺省值为NULL。

2. 修改查询Q_1,将SQL查询语句修改为0select  from dept &.&.w_clause。

3. 在运行报表时,报表会自动将符合&.&.w_clause的查询条件记录显示出来。

如果从FORM传递过来的w_clause为where dept=1,本报表的SQL查询自动转换为0select  from dept where dept=1,并在报表运行结果中显示符合该查询条件的记录,如果从FORM传递过来的w_cluase为where to_char(年度,YYYY.MM)=2000.03,则在报表运行结果中自动显示2000年3月份的记录。

问:在Oracle中,我们如何查看某表上的约束?


相关文章


案例学习Oracle错误:ORA-00604(2)
案例学习Oracle错误:ORA-00604(4)
Oracle数据库的常用函数列表一览
案例学习Oracle错误:ORA-00604(1)
Oracle数据库的常见问题答疑之集锦(1)
Oracle数据库执行计划的一些基本概念(1)
OracleSQL内置函数的使用方法及结果(4)
OracleSQL内置函数的使用方法及结果(2)
Oracle10g中新的多重集运算符解析
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛