您的位置:首页技术开发数据库安全 → Oracle数据库常见问题答疑

Oracle数据库常见问题答疑

时间:2010/1/29 17:56:00来源:本站整理作者:我要评论(0)

Oracle数据库常见问题答疑:

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

  问:如果发现表中有坏块,如何检索其它未坏的数据?
  答:首先需要找到坏块的ID(可以运行dbverify实现),假设为1234。运行下面的查询查找段名:

  select 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

  select  from bad_table where rowid not in

  ( select /+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查询语句修改为select  from dept &w_clause。

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

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

问:在Oracle中,我们如何查看某表上的约束?
  答:我们可以使用下面语句从all_constraints视图中查看某表上的约束:

  SELECT constraint_name, table_name, r_owner, r_constraint_name

  FROM all_constraints

  WHERE table_name = ‘table_name‘ and owner = ‘owner_name‘;

  另一个视图ALL_CONS_COLUMNS也包括组成表上约束列的信息。

  问:如何将数据库从noarchivelog方式改变为archivelog方式?
  答:首先打开Init.ora文件,确保存档日志目标指向一有效目录。

  然后启动Server Manager

  svrmgrl〉 shutdown immediate

  svrmgrl〉 startup mount

  svrmgrl〉 alter database archivelog;

  svrmgrl〉 alter database open;

  svrmgrl〉 archive log list;

  在init.ora中设置参数archive_log_start=TRUE,它设置存档日志为自动启动。在Oracle 8i中支持多个存档日志的目标,因此参数修改为log_archive_dest[n],其中n为1到5。

  问:在Oracle数据库中,我们如何增加表空间的大小?
  答: 在开发Oracle数据库中,我们有两种方法增加表空间的大小:

  1.增加额外的数据文件到表空间中

  例如:alter tablespace users add datafile ‘/u01/oradata/orcl/users02.dbf‘ size 25m;

  2.修改表空间当前的数据文件

  例如:alter database datafile

  ‘/u01/oradata/orcl/users01.dbf‘ resize 50M;

  问:请问如何在REPORT中设置动态显示域?
  答:在REPORT中设置动态显示域的方法如下:

  1. 在REPORT的“数据模型”下面的“用户参数”中,创建用户自定义参数,如RQ,RQ是从FORM传递过来的显示日期,数据类型为字符型。

  2. 在布局模型中,创建一个显示域F_1,在属性选项板中修改该显示域的源为用户自定义参数RQ,并且设为“不可见的”。

  3. 在动态预览中,创建一个文本域D_1,调整该文本域的位置和宽度,在该域的内容中输入&F_1,则该域会动态显示用户定义参数RQ的值。
 

 

相关视频

    没有数据

相关阅读 数据库流行度排行2019年9月 数据库排行榜2019年最新版fifa online4数据库大全 fifa online4球员数据库在哪myeclipse怎么连接到数据库 myeclipse连接到数据库方法PLSQL Developer怎么导出数据库PLSQL Developer配置Oralce11g连接plsql developer怎么使用 plsql developer使用教程plsql developer怎么连接数据库 plsql developer连接数据库教程mysql数据库root密码忘记的修改方法

文章评论
发表评论

热门文章 没有查询到任何记录。

最新文章 没有查询到任何记录。 数据库安全技术研究如何看清楚SQL注入SQL SERVER数据库口令的脆弱性MySQL不安全临时文件建立漏洞

人气排行 MySQL3.23.31之前版本的安全漏洞网站入侵过程!如何看清楚SQL注入通过mysql入侵NT和win2000Mysql数据库的安全配置、实用技巧SQL数据库的一些攻击 SQL Server补丁安装常见问题SQL SERVER数据库口令的脆弱性