Oracle笔试题库之问答题篇-总共60道

1.把表A从表空间TSP1更改成表空间TSP2的方法

解答:

alter table A move tablespace TSP2

2.删除表的列;

解答:alert table 表名 drop 列名

123.删除表空间的数据文件?

解答:用SQLPLUS命令: drop tablespace tablename including contents 就可以把所有相关的数据删除

4.如何用ALTER命令把表数据加到缓存表里,清除呢?

解答:添加:alert table 表名 cache

清除:alert table 表名 nocache

5.数据的复制实现办法?

解答:数据复制,就是将数据库中的数据拷贝到另外一个或多个不同的物理站点上,从而保持源数据库与目标数据库中指定数据的一致性。

数据复制的实现方法:在具体的实现之前,首先要做好设计与规划。这就需要细致分析具体的业务情况,设计出一套能够满足业务需要的方案。通常在设计过程中,需要确定出要建立的数据库站点,各站点的类型,需要复制的数据对象,以及同步方式、冲突解决方案等内容。

数据复制的实现主要包括以下几步:(1)创建复制站点。(2)创建组对象。(3)配置冲突解决方案。

6.建立ORACLE数据库后,系统自带的两个用户是什么,相应的密码是什么?他们的身份是什么?

解答: 用户 密码 身份 System manager SYSDBA Sys change_on_instal SYSDPER

7.在建立ORACLE数据库时,选择“事务处理”模板与选用“数据仓库”模板的

区别是什么?

解答:事物处理型:经常反馈给客户信息,处理大容量或超大容量的数据. 数据仓库型:主要频繁处理小型数据库,只是进行一些查询等操作.

8、在使用OMS之前需要建立资料档案库。在建立资料档案库的时候,在“为资料档案库选择数据库”选项卡中输入的服务名称应该如何写。(比如你要连接192.168.1.2机器上的SIST数据库)。

解答:192.168.1.2:1521:SIST

9、登陆OMS所使用的用户名和密码分别为什么?如果在登陆时,系统提示找不到服务,你应该如何处理?

解答:用户名:SYSMAN, 密码:OEM_TEMP 问题出现在服务器没有启动,只能通过手动的方法在Windows管理工具下的策略中将服务器启动。 10、请说出两种以上扩大数据库的方式

解答 1) 修改现有表空间的大小; 2)向表空间插入一个新的数据文件.

11在ORACLE中的物理文件包含哪四种?

解答:1)数据文件 扩展名为*.dbf 2)控制文件 扩展名为*.rtl 3)配置文件 扩展名为*.ora 4)日志文件 扩展名为*.dbf

12. 日志文件(记录文件)有哪几种,分别介绍他们的工作模式。

解答: 归档日志:当日志写满,完成一次循环之前建立一个副本。这样数据库就可以在损坏中得到恢复。恢复的过程相当于把建库的所有动作重新做一次。最安全的数据库工作方式,占用空间也最大 非归档日志:日志写满后,直接覆盖,它只是部分地记录数据库操作,所以恢复能力有限。

13、简要写出在system方案中建立序列xl的步骤。 解答:

create squence system.xl start whith 1 increment by 1 minvalue 1

nomaxvalue nocycle nocache order;

14、写出SQL语句,向表中插入一条记录,其中ID字段的值来自序列XL。

Insert into system.table1 values (xl.nextval,’tom’,21,’男’,2000); 

15、 写出一个匿名的SQL程序块,完成如下任务:向表中插入3000条记录,在salary字段中有500条记录的值为1000,500条记录的值为1200,1000条记录的值为1500,1000条记录的值为1800 Id 字段的值来自序列xl,其他字段的值任意.

declare x number:=0;
begin for x in 1..3000 loop
If(x<=500) then Insert into system.test values(x1.nextval,’jim’,24,’m',1000);
elsif((x>500)and (x<1001))
then Insert into system.test values(system.xl1.nextval,’jim’,24,’m
',1200);
Elsif((x>1000)and (x<2001)) then Insert into system.test values(system.xl1.nextval,’jim’,24,’m',1500);
Else Insert into system.test values(system.xl1.nextval,’jim’,24,’m
',1800);
end if;
end loop;
end;

 

16、写出一个存储过程,这个存储过程的作用是修改特定id编号的记录,将该条记录的salary字段的值加上500;

Create or replace procedure system.update_age (vid in number) is Begin Update table1 set salary=salary+500 where id=vid;

End;


17、用SQL语句创建个一个视图,这个视图用来显示ID>1000的记录; 解答:

create view st as select * from table1 where id>1000;

 

18、创建一个system方案中的函数fn1,函数作用为:将指定ID号的记录中的salary字段值乘以1.05。

Create or replace function system.fn1(salary1 system.table1 salary &type) Return number as V1 numbre:=1.05; V2 numbre; 
Begin V2=v1*salary1;
 Return v2; End ;


19.解释冷备份和热备份的不同点以及各自的优点

解答:热备份针对归档模式的数据库,在数据库仍旧处于工作状态时进行备份。而冷备份指在数据库关闭后,进行备份,适用于所有模式的数据库。热备份的优点在于当备份时,数据库仍旧可以被使用并且可以将数据库恢复到任意一个时间点。冷备份的优点在于它的备份和恢复操作相当简单,并且由于冷备份的数据库可以工作在非归档模式下,数据库性能会比归档模式稍好。(因为不必将archive log写入硬盘)

20. 你必须利用备份恢复数据库,但是你没有控制文件,该如何解决问题呢?

解答:重建控制文件,用带backup control file 子句的recover 命令恢复数据库。 141. 如何转换init.ora到spfile?

解答:使用create spfile from pfile 命令 142. 解释data block , extent 和 segment的区别(这里建议用英文术语)

解答:data block是数据库中最小的逻辑存储单元。当数据库的对象需要更多的物理存储空间时,连续的data block就组成了extent . 一个数据库对象拥有的所有extents被称为该对象的segment.

23. 给出两个检查表结构的方法

解答:1、DESCRIBE命令 2、DBMS_METADATA.GET_DDL 包

24. 怎样查看数据库引擎的报错

解答:alert log.

25. 使用索引的理由

解答:快速访问表中的data block

26. 给出在STAR SCHEMA中的两种表及它们分别含有的数据

解答:Fact tables 和dimension tables. fact table 包含大量的主要的信息而 dimension tables 存放对fact table 某些属性描述的信息

27. FACT Table上需要建立何种索引?

解答:位图索引(bitmap index)

28. 给出两种相关约束?

解答:主键和外键

29. 如何在不影响子表的前提下,重建一个母表

解答:子表的外键强制失效,重建母表,激活外键

30. 如何建立一个备份控制文件?

解答:Alter database backup control file to trace.

31. 给出数据库正常启动所经历的几种状态 ?

解答: STARTUP NOMOUNT – 数据库实例启动 STARTUP MOUNT – 数据库装载 STARTUP OPEN – 数据库打开

32. 哪个column可以用来区别V$视图和GV$视图?

解答: INST_ID 指明集群环境中具体的某个instance 。

33. 如何生成explain plan?

解答: 运行utlxplan.sql. 建立plan 表针对特定SQL语句,使用 explain plan set statement_id = ‘tst1′ into plan_table 运行utlxplp.sql 或 utlxpls.sql察看explain plan

34. 如何增加buffer cache的命中率?

解答:在数据库较繁忙时,适用buffer cache advisory 工具,查询v$db_cache_advice . 如果有必要更改,可以使用 alter system set db_cache_size 命令

35. 解释$ORACLE_HOME和$ORACLE_BASE的区别?

解答:ORACLE_BASE是oracle的根目录,ORACLE_HOME是oracle产品的目录

36. 如何判断数据库的时区?

解答:SELECT DBTIMEZONE FROM DUAL

37. 解释GLOBAL_NAMES设为TRUE的用途

解答:GLOBAL_NAMES指明连接数据库的方式。如果这个参数设置为TRUE,在建立数据库链接时就必须用相同的名字连结远程数据库

38.如何加密PL/SQL程序?

解答:WRAP

39. 解释TABLE Function的用途

解答:TABLE Function是通过PL/SQL逻辑返回一组纪录,用于普通的表/视图。他们也用于pipeline和ETL(ETL,Extraction-Transformation-Loading的缩写,中文名称为数据提取、转换和加载)过程。

40. 举出3种可以收集three advisory statistics

解答:Buffer Cache Advice, Segment Level Statistics, Timed Statistics

41. Audit trace 存放在哪个oracle目录结构中?

解答:unix $ORACLE_HOME/rdbms/audit

Windows the event viewer

42. 解释materialized views的作用

解答:Materialized views 用于减少那些汇总,集合和分组的信息的集合数量。它们通常适合于数据仓库和DSS系统

43. 当用户进程出错,哪个后台进程负责清理它

解答: PMON

44. 哪个后台进程刷新materialized views?

解答:The Job Queue Processes.

45. 如何判断哪个session正在连结以及它们等待的资源?

解答:V$SESSION / V$SESSION_WAIT

46. 描述什么是 redo logs

解答:Redo Logs 是用于存放数据库数据改动状况的物理和逻辑结构。可以用来修复数据库

47. 如何进行强制LOG SWITCH?

解答:ALTER SYSTEM SWITCH LOGFILE;

48. 举出两个判断DDL改动的方法?

解答:你可以使用 Logminer 或 Streams

49. Coalescing做了什么?

解答:Coalescing针对于字典管理的tablespace进行碎片整理,将临近的小extents合并成单个的大extent.

50. TEMPORARY tablespace和PERMANENT tablespace 的区别是?

解答:temporary tablespace 用于临时对象例如排序结构而 permanent tablespaces用来存储那些’真实’的对象(例如表,回滚段等)

51. 创建数据库时自动建立的tablespace名称?

解答:SYSTEM tablespace.

52. 创建用户时,需要赋予新用户什么权限才能使它联上数据库。

解答:CONNECT

53. 如何在tablespace里增加数据文件?

解答:ALTER TABLESPACE <tablespace_name> ADD DATAFILE <datafile_name> SIZE <size>

54. 如何变动数据文件的大小?

解答:ALTER DATABASE DATAFILE <datafile_name> RESIZE <new_size>;

55. 哪个VIEW用来检查数据文件的大小?

解答: DBA_DATA_FILES

56. 哪个VIEW用来判断tablespace的剩余空间

解答:DBA_FREE_SPACE

57. 如何判断谁往表里增加了一条纪录?

解答:auditing

58. 如何重构索引?

解答: ALTER INDEX <index_name> REBUILD;

59. 解释什么是Partitioning(分区)以及它的优点。

解答:Partition将大表和索引分割成更小,易于管理的分区。

60. 你刚刚编译了一个PL/SQL Package但是有错误报道,如何显示出错信息?

解答:SHOW ERRORS

posted @ 2013-08-17 20:34  残阳飞雪  阅读(882)  评论(0编辑  收藏  举报