oracle数据库50题,ORACLE数据库试题

《ORACLE数据库试题》由会员分享,可在线阅读,更多相关《ORACLE数据库试题(10页珍藏版)》请在人人文库网上搜索。

1、ORACLE数据库试题1. 以下关于数据的逻辑结构的叙述中,哪一条是不正确的?( C )A数据的逻辑结构是数据间关系的描述 B数据的逻辑结构抽象地反映数据元素间的逻辑关系 C数据的逻辑结构具体地反映数据在计算机中的存储方式 D数据的逻辑结构分为线性结构和非线性结构 2. 以下关于链式存储结构的叙述中,哪一条是不正确的?( C )A结点除自身信息外还包括指针域,因此存储密度小于顺序存储结构 B逻辑上相邻的结点物理上不必邻接 C可以通过计算直接确定第i个结点的存储地址 D插入、删除运算操作方便,不必移动结点 3. 下列关于文件索引结构的叙述中,哪一个是不正确的?( A )A采用索引结构,逻辑上连续。

2、的文件存放在连续的物理块中 B系统为每个文件建立一张索引表 C索引结构的优点是访问速度快,文件长度可以动态变化 D索引结构的缺点是存储开销大 4. 下列关于数据库数据模型的说法中,哪一个是不正确的?( A )A任何一张二维表都表示一个关系 B层次模型的数据结构是有向树结构 C在网状模型中,一个子结点可以有多个父结点 D在面向对象模型中每一个对象都有一个惟一的标识 5. 下列关于数据库三级模式结构的说法中,哪一个是不正确的?( D )A数据库三级模式结构由内模式、模式和外模式组成 BDBMS在数据库三级模式之间提供外模式/模式映象和模式/内模式映像 C外模式/模式映象实现数据的逻辑独立性 D一个。

3、数据库可以有多个模式 6. 如果在一个关系中,存在某个属性(或属性组),虽然不是该关系的主码或只是主码的一部分,但却是另一个关系的主码时,称该属性(或属性组)为这个关系的( C )A候选码 B主码 C外码 D连接码 7. 下列关于关系数据库视图的说法中,哪些是正确的?( B ). 视图是关系数据库三级模式中的内模式。 . 视图能够对机密数据库提供一定的安全保护。 . 视图对重构数据库提供了一定程度的逻辑独立性。 . 对视图的一切操作最终都要转换为对基本表的操作。 . 所有的视图都是可以更新的。A、和 B、和 C、和 D都正确 第(8)-(9)题基于学生-课程数据库中的三个基本表: 学生信息表:。

4、s(sno, sname, sex, age, dept) 主码为sno 课程信息表:c(cno, cname, teacher) 主码为cno 学生选课信息表:sc(sno, cno, grade) 主码为(sno, cno) 8. 从学生选课信息表中找出无成绩的元组的SQL语句是( C )ASELECT * FROM sc WHERE grade=NULL BSELECT * FROM sc WHERE grade IS CSELECT * FROM sc WHERE grade IS NULL DSELECT * FROM sc WHERE grade = 9. 在查询选修课程号为4,且。

5、成绩在80分以上的所有学生的学号和姓名的SQL语句中,将使用的表是( D )A学生信息表S B学生信息表S和课程信息表c C学生信息表S、课程信息表c和学生选课信息表sc D学生信息表S和学生选课信息表sc 10. 数据库结构的描述和定义是DBMS运行的基本依据,它们存储于( B )A封锁表 B数据字典 C索引 D日志 11. 数据库管理系统的数据操纵语言(DML)所实现的操作一般包括( D )A建立、授权、修改 B建立、授权、删除 C建立、插入、修改、排序 D查询、插入、修改、删除 12. 在对数据库的系统故障进行恢复时,需要对日志文件进行( B )A反向扫描 B正向扫描 C双向扫描 D随机。

6、扫描 13. 下列权限中,哪一个不是数据库的访问权限?( D )ARead权限 BResource权限 CUpdate权限 DLock权限 14. E-R模型用于数据库设计的哪一个阶段? ( B )A需求分析 B概念结构设计 C逻辑结构设计 D物理结构设计 15. 如果要求应用软件具有很好的可扩充性、可移植性、互操作性,那么软件系统的前端开发工具主要应具有下述哪一个特征?( C )A支持面向对象的程序设计 B支持与多种数据库联结 C支持开放性 D工具的完备性要好 16. 在数据库中可以创建和删除表、视图、索引,可以修改表。这是因为数据库管理系统提供了( A )A)数据定义功能 B)数据操纵功能。

7、 C)数据维护功能 D)数据控制功能17. 数据库系统一般由哪些成分构成?( D )I数据库 II数据库管理员 III数据库管理系统及其工具 IV用户 V操作系统 VI应用系统A)I、II 和III B)I、II、III和IV C)I、II、III、IV和V D)全部18. 在关系数据库中,索引(index)是三级模式结构中的( B )A)概念模式 B)内模式 C)模式 D)外模式19. 下面所列各项,哪些属于数据库技术的研究领域?( C )I数据库管理系统软件的研制 II数据库设计 III数据库理论 IV操作系统 A)I和II B)I和III C)I、II 和III D)全部20. 在关系数。

8、据库系统中,当合并两个关系时,用户程序可以不变。这是( C )A)数据的物理独立性 B)数据的位置独立性 C)数据的逻辑独立性 D)数据的存储独立性21. 在面向对象数据模型中,子类不但可以从其超类中继承所有的属性和方法,而且还可以定义自己的属性和方法,这有利于实现( B )A)可移植性 B)可扩充性 C)安全性 D)可靠性22. 关系模型有三类完整性约束:实体完整性、参照完整性和用户定义的完整性。定义外键实现的是哪一(些)类完整性?( B )A)实体完整性B)参照完整性C)用户定义的完整性D)实体完整性、参照完整性和用户定义的完整性23. 下面关于SQL语言的说法中,哪一种说法是错误的?( 。

9、A )A)一个SQL数据库就是一个基本表B)SQL语言支持数据库的三级模式结构C)一个基本表可以跨多个存储文件存放,一个存储文件可以存放一个或多个基本表D)SQL的一个表可以是一个基本表,也可以是一个视图24. 下面所列条目中,哪一条不是标准的SQL语句?( B )A)ALTER TABLE B)ALTER VIEWC)CREATE TABLE D)CREATE VIEW25. 在数据库管理系统的层次结构中,数据存取层处理的对象是( B )A)字段 B)单个元组 C)数据页 D)系统缓冲区26. 下列哪种数据库系统更适合于在大、中型计算机系统上使用?( C )A)FoxPro B)Access。

10、C)Oracle D)Microsoft SQL Server27. 对数据库数据的删除是由数据库管理系统的哪个功能模块实现的?( A )A)数据库存取功能模块B)数据库存储管理功能模块C)数据库运行处理功能模块D)数据库维护功能模块28. 数据库系统的日志文件用于记录下述哪类内容?( D )A)程序运行过程 B)数据查询操作C)程序执行结果 D)数据更新操作29. 实现数据库的哪个特性能够避免对未提交更新的依赖(脏数据的读出)? ( B )A)完整性 B)并发性 C)安全性 D)可移植性30. 下述哪一条不属于数据库设计的内容?( A )A)设计数据库管理系统B)设计数据库概念结构C)设计数。

11、据库逻辑结构D)设计数据库物理结构31. 下述哪一条是由于关系模式设计不当所引起的问题?( B )A)丢失修改 B)更新异常C)读脏数据 D)数据被非法读取32. 最优执行计划的选择原则是: ( C ) A) 能出结果 B) 速度最快 C) 读取最少 D) 以上所有33. 决定SQL语句的性能可被接受项目接受取决于 ( A )A) 执行速度最快 B) 在正确的模拟环境下,达到应用的非功能需求 C) 读取最少 D) 排序次数最少 34. 对于索引以下正确的描述是 ( D )A) 索引可以加快查询效率 B) 索引与DML速度无关 C) 索引创建后会自动被Oracle使用 D) 索引扫描未必优于全表。

12、扫描 35. 数据库系统的核心是( B ) A.数据库 B.数据库管理系统 C.数据模型 D.软件工具36. 在一个关系中,如果有这样一个属性存在,它的值能唯一的标识此关系中的一个元组,称其为( A ). A.主键 B.数据项 C.重要属性 D.主属性值37. 数据库(DB),数据库系统(DBS)和数据库管理系统(DBMS)三者之间的关系是( A ) A.DBS包括DB和DBMS B.DBMS包括DB和DBS C.DB包括DBS和DBMS D.DBS就是DB,也就是DBMS 38. 在数据操纵语言(DML)的基本功能中,不包括的是( B ) A.插入新数据 B.描述数据库结构C.对数据库中数据。

13、排序 D.删除数据库中数据39. 在数据库技术中,独立于计算机系统的模型是( C )。A、面向对象的模型 B、关系模型 C、E-R模型 D、层次模型40. 在关系数据库中,建立数据库表时,将年龄字段值限制在1240岁之间的这种约束属于( B )。A、视图完整性约束 B、域完整性约束C、参照完整性约束 D、实体完整性约束41. 数据库的并发操作可能带来的问题包括( B )。A非法用户的使用 B丢失更新C数据独立性会提高 D增加数据冗余度42. 在关系数据库中,模式对应的是( C )。 A、视图和所有基本表 B、视图和部分基本表 C、基本表 D、索引43. 在下列描述中,正确的描述是( B )。 。

14、A、SQL 是一种过程化语言 B、SQL 采用集合操作方式C、SQL 不能嵌入到高级语言程序中 D、SQL 是一种 DBMS 44. 在SQL查询时,使用WHERE子句指出的是( B )。 A、查询目标 B、查询条件 C、查询视图 D、查询结果45. 数据库类型是按照( A )来划分的。 A、数据模型 B、记录形式 C、数据存取方法 D、文件形式46. 简单地说,分布式数据库的数据( B ) A、逻辑上分散,物理上统一 B、物理上分散,逻辑上统一 C、逻辑上和物理上都统一 D、逻辑上和物理上都分散47. 在支持用户的应用方面,DDBS的主要特点是支持( B ) A、局部应用 B、全局应用 C、。

15、分散应用 D、场地自治48. 在客户/服务器体系结构的DBS中,数据库功能分为前端和后端两部分,下列功能中属于前端的是( C ) A、存取结构 B、查询优化 C、用户界面 D、并发控制49. 分布式数据库系统中,查询处理的时间主要取决于( D ) A、CPU执行时间 B、数据库的数据量 C、I/O花费的时间 D、网络中数据传输量50. 分布式数据库是数据库技术和( B )结合的产物。 A、面向对象技术 B、计算机网络 C、数据分离技术 D、数据分布技术51. 对数据库按其存放方式进行分类:一个数据库存放在一台计算机之中为__数据库,一个数据库存放在若干个计算机之中称为( A )数据库。 A、集。

16、中式、分布式 B、集中式、关系式 C、关系式、连接式 D、关系式、分布式52. 对于系统表的空间,Oracle建议的大小是( C )A. 200 MB; B. 300MB; C. 400MB; D. 500 MB。53. 下列数据库模式对象中,具有INDEX对象权限的是( A )A. 表; B. 过程; C. 序列; D. 函数。54. 在关系模式中,视图是三级模式结构中的 ( D ) A. 内模式 B. 模式 C. 存储模式 D. 外模式55. 对于学生选课课程的三个关系 S(S#,SNAME,SEX,AGE) SC(S#,C#,GRADE) C(C#,CNAME,TEACHER) 为了提高。

17、查询速度,对SC表创建唯一索引,应建哪个组上 ( A ) A. (S#,C#) B. S# C. C# D. GRADE 56. .接上题,为了考虑安全性,每个教师只能存取自己讲授的课程的学生成绩,应创建 ( A ) A. 视图 B. 索引 C. 游标 D. 表57. 在数据库技术中,反映现实世界中事物的存在方式和运动状态的是 ( A ) A. 信息 B. 数据 C. 消息 D. 命令58. 文件系统的多级目录结构是 ( B ) A. 线性结构 B. 树形结构 C. 散列结构 D. 双链表结构59. 在关系数据库中,当关系的型改变时,用户程序也可以不变。这是 ( B ) A. 物理独立性 B.。

18、 逻辑独立性 C. 位置独立性 D. 存储独立性60. 下列关于“分布式数据库系统”的叙述中,正确的是 ( C ) A. 分散在各结点的数据是不相关的 B. 用户可以对远程数据进行访问,但必须指明数据的存储结点 C. 每一个结点是一个独立的数据库系统,既能完成局部应用,也支持全局应用 D. 数据可以分散在不同结点的计算机上,但必需在同一台计算机上进行数据处理61. SQL语句中修改表结构的命令是( C )。 A、MODIFYTABLE B、MODIFYSTRUCTURE C、ALTERTABLE D、ALTERSTRUCTURE62. 如果要创建一个数据组分组报表,第一个分组表达式是部门,第二。

19、个分组表达式是性别,第三个分组表达式是基本工资,当前索引的索引表达式应当是( B )。 A、部门+性别+基本工资 B、部门+性别+STR(基本工资) C、STR(基本工资)+性别+部门 D、性别+部门+STR(基本工资)63. 数据库DB、数据库系统DBS、数据库管理系统DBMS三者之间的关系是( A )。 A、DBS包括DB和DBMS B、DBMS包括DB和DBS C、DB包括DBS和DBMS D、DBS就是DB,也就是DBMS64. 要控制两个表中数据的完整性和一致性可以设置参照完整性,要求这两个表( A )。 A、是同一个数据库中的两个表 B、不同数据库中的两个表 C、两个自由表 D、一。

20、个是数据库表另一个是自由表65. 索引字段值不唯一,应该选择的索引类型为( B )。 A、主索引 B、普通索引 C、候选索引 D、唯一索引66. 从数据库中删除表的命令是( A )。 A、DROPTABLE B、ALTERTABLE C、DELETETABLE D、USE67. SELECT-SQL语句是( B )。 A、选择工作区语句 B、数据查询语句 C、选择标准语句 D、数据修改语句68. DELETEFROMSWHERE年龄60语句的功能是( B )。 A、从S表中彻底删除年龄大于60岁的记录 B、S表中年龄大于60岁的记录被加上删除标记 C、删除S表 D、删除S表的年龄列69. 22。

21、.SQL语言是( C )语言。 A、层次数据库 B、网络数据库 C、关系数据库 D、非数据库 70. 在SQL中,删除视图用( C )。 A、DROPSCHEMA命令 B、CREATETABLE命令 C、DROPVIEW命令 D、DROPINDEX命令71. DBAS指的是( C )。 A、数据库管理系统 B、数据库系统C、数据库应用系统 D、数据库服务系统72. ( C )模式存储数据库中数字典的表和视图A、DBA B、SCOTT C、SYSTEM D、SYS 73. 在Oracle中创建用户时,若未提及DEFAULT TABLESPACE关键字,则Oracle就将(C)表空间分配给用户作为。

22、默认表空间。A、HR B、SCOTT C、SYSTME D、SYS 74. 在SELECT语句中使用( D )子句来只显示工资超过5000的员工A、 ORDER BY SALARY 5000B、 GROUP BY SALARY 5000C、 HAVING SALARY 5000D、 WHERE SALARY 500075. ( B )函数通常用来计算累计排名、移动平均数和报表聚合等。A、汇总 B、分析 C、分组 D、单行76. 锁用于提供( B )A、改进的性能 B、数据的完整性和一致性C、可用性和易于维护 D、用户安全77. ( C )锁用于锁定表,允许其他用户查询表中的行和锁定表,但不允许。

23、插入、更像和删除行。A、行共享 B、行排他 C、共享 D、排他78. 要以自身的模式创建私有同义词,用户必须用于( A )系统权限A、 CREATE PRIVATE SYNONYMB、 CREATE PUBLIC SYNONYMC、 CREATE SYNONYMD、 CREATE ANY SYNONYM79. 事务的持久性是由数据库管理系统中的哪个部件负责?( A )A)恢复管理 B)并发控制C)完整性约束 D)存储管理80. 下面关于函数依赖的叙述中,错误的是( C )A)若X Y,Y Z,则 X Z B)若X Y, Y,则X C)若X Y, X,则 Y D)若 X,则X81. 现有如下关系。

24、:职工(职工号,姓名,性别,职务) 部门(部门编号,部门名称,职工号,姓名,部门地址,电话) 其中,部门关系中的外码是( D ) A.部门编号 B.姓名 C.职工号 D职工号,姓名82. 在数据库技术中,独立于计算机系统的模型是( C )。A、面向对象的模型 B、关系模型 C、E-R模型 D、层次模型83. 在关系数据库中,建立数据库表时,将年龄字段值限制在1240岁之间的这种约束属于( B )。A、视图完整性约束 B、域完整性约束C、参照完整性约束 D、实体完整性约束84. 在 SQL 语句中,与 X BETWEEN 20 AND 30 等价的表达式是( D )。 A、X=20 AND X2。

25、0 AND X20 AND X=20 AND X=3085. 在数据库中,概念模型是( D )。 A、用于现实的建模,与具体的DBMS有关 B、用于信息世界的建模,与具体的DBMS有关 C、用于现实的建模,与具体的DBMS无关 D、用于信息世界的建模,与具体的DBMS无关86. 数据库的并发操作可能带来的问题包括( B )。A非法用户的使用 B丢失更新C数据独立性会提高 D增加数据冗余度87. 在下列描述中,正确的描述是( B )。 A、SQL 是一种过程化语言 B、SQL 采用集合操作方式C、SQL 不能嵌入到高级语言程序中 D、SQL 是一种 DBMS88. 数据库系统是由( A )组成的。

26、。 A、数据库、数据库管理系统和用户 B、数据文件、命令文件和报表 C、数据库文件结构和数据 D、常量、变量和函数89. 在SQL查询时,使用WHERE子句指出的是( B )。 A、查询目标 B、查询条件 C、查询视图 D、查询结果90. 在下列 RDMBS 产品中,属于小型数据库系统的是( A )。 A、Access B、Oracle C、Sybase D、Informix91. 数据库类型是按照( A )来划分的。 A、数据模型 B、记录形式 C、数据存取方法 D、文件形式92. 客户/服务器体系结构的关键在于( B ) A、计算的分布 B、功能的分布 C、CPU的分布 D、数据的分布93。

27、. 客户/服务器体系结构功能分布的结果是减轻了( A ) A、服务器的负担 B、I/O通道的压力 C、客户端的负担 D、CPU的负担94. 在客户/服务器体系结构的DBS中,数据库功能分为前端和后端两部分,下列功能中属于后端的是( D ) A、数据输入 B、报表输出 C、用户界面 D、存取结构95. 在客户/服务器体系结构的DBS中,数据库功能分为前端和后端两部分,下列功能中属于前端的是( C ) A、存取结构 B、查询优化 C、用户界面 D、并发控制96. 分布式数据库系统中,查询处理的时间主要取决于( D ) A、CPU执行时间 B、数据库的数据量 C、I/O花费的时间 D、网络中数据传输量97. 分布式数据库是数据库技术和( B )结合的产物。 A、面向对象技术 B、计算机网络 C、数据分离技术 D、数据分布技术98. PL/SQL块中不能直接使用的SQL命令是( D )A、SELECT B、INSERT C、UPDATE D、DROP99. ( D )语句将控制权转到标号指定的语句或块中。A、IF-THEN B、IF-THEN-ELSE C、FOR D、CASE100. 以零作除数时会引发( B )异常A、VALUE_ERROR B、ZERO_DIVIDE C、STORAGE_ERROR D、SELF_IS_NUL。

一、填空 1.在多进程Oracle实例系统中,进程分为用户进程、后台进程和服务进程。 2.标准的SQL语言语句类型可以分为:数据定义语句(DDL)、数据操纵语句(DML)和数据控制语句(DCL)。 3.在需要滤除查询结果中重复的行时,必须使用关键字Distinct; 在需要返回查询结果中的所有行时,可以使用关键字ALL。 4.当进行模糊查询时,应使用关键字like和通配符问号(?)或百分号"%"。 5.Where子句可以接收From子句输出的数据,而HAVING子句则可以接收来自WHERE、FROM或GROUP BY子句的输入。 6.在SQL语句中,用于向表中插入数据的语句是Insert。 7.如果需要向表中插入一批已经存在的数据,可以在INSERT语句中使用Select语句。 8.使用Describe命令可以显示表的结构信息。 9.使用SQL*Plus的Get命令可以将文件检索到缓冲区,并且不执行。 10.使用Save命令可以将缓冲区中的SQL命令保存到一个文件中,并且可以使用Run命令运行该文件。 11.一个模式只能够被一个数据库对象所拥有,其创建的所有模式对象都保存在自己的模式中。 12.根据约束的作用域,约束可以分为表级约束和列级约束两种。列级约束是字段定义的一部分,只能够应用在一个列上;而表级约束的定义独立于列的定义,它可以应用于一个表中的多个列。 13.填写下面的语句,使其可以为Class表的ID列添加一个名为PK_CLASS_ID的主键约束。 ALTER TABLE Class Add ____________ PK_LASS_ID (Constraint) PRIMARY KEY ________ (ID) 14. 每个Oracle 10g数据库在创建后都有4个默认的数据库用户:system、sys、sysman和DBcnmp 15. Oracle提供了两种类型的权限:系统权限和对象权限。系统权限提供了在Oracle数据库系统范围内执行某种任务的操作能力,而对象权限则是一种赋予用户在指定的数据库对象(如表、视图、过程等) 16. Oralce数据库在进行物理备份有联机备份和脱机备份两种方式可供选择。 . 17. 从存储结构的角度来说,Oracle数据库可分为物理结构逻辑结构。 18. 表空间是Oracle数据库中数据的逻辑组织,每个数据库至少有一个SYSTEM系统表空间。 19.视图是一个表示表的数据的数据库对象,它允许用户从一个表或一组表中通过一定的查询语句建立一个“虚表”。 20.序列是一种可被多个用户使用的用于产生一系列唯一数字的数据库对象。尤其适合多用户环境中,可以生成唯一的序列号而没有磁盘I/O或事务处理锁定开销。 21. 一个表空间具有离线(OFFLINE)、在线(ONLINE)、只读(READ ONLY)、读写(READ WRITE)状态。 二、选择 1.在全局存储区SGA中,哪部分内存区域是循环使用的?( B ) A.数据缓冲区 B.日志缓冲区 C. 共享池 D.大池 2.如果一个服务器进程非正常终止,Oracle系统将使用下列哪一个进程来释放它所占用的资源?( D ) A.DBWR B.LGWR C. SMON D.PMON 3. 如果要查询数据库中所有表的信息,应当使用下列哪种数据字典视图?( A ) A. DBA视图 B. ALL视图 C. USER视图 D. 动态性能视图 4. 下列哪一项是Oracle数据库中最小的存储分配单元? ( C ) A. 表空间 B. 段 C. 盘区 D. 数据块 5. 下面的各选项中哪一个正确描述Oracle数据库逻辑存储结构? ( A ) A. 表空间由段组成,段由盘区组成,盘区由数据块组成 B. 段由表空间组成,表空间由盘区组成,盘区由数据块组成 C. 盘区由数据块组成,数据块由段组成,段由表空间组成 D. 数据块由段组成,段由盘区组成,盘区由表空间组成 6. 下列的哪个子句在SELECT语句中用于排序结果集?( D ) A. Having子句 B. Where子句 C. From子句 D. Order by子句 7. Having子句的作用是( B )。 a. 查询结果的分组条件 B. 组的筛选条件 C. 限定返回的行的判断条件 D. 对结果集进行排序 8. 下列哪个函数可以把一个列中的所有值相加求和? ( B ) A MAX B. SUM C. COUNT D. AVG 9. 下列哪个子句是SELECT语句中必选项?( A ) A. FROM B.WHERE C.HAVING D. ORDER BY 10. 下列哪个子句实现对一个结果集进行分组和汇总?( D ) A.HAVING B. ORDER BY C. WHERE D. GROUP BY 11. 查询一个表的总记录数,可以采用_________统计函数。( C ) A. AVG(*) B. SUM(*) C. COUNT(*) D.MAX(*) 12. 要建立一个语句向Types表中插入数据,这个表只有两列,T_ID和T_Name列。如果要插入一行数据,这一行的T_ID值是100,T_Name值是RFUIT。应该使用的SQL语句是_____。( A ) A. INSERT INTO Type Values(100, ‘FRUIT’) B. SELECT * FROM Type WHERE T_ID=100 AND T_NAME=’FRUIT’ C. UPDATE SET T_ID=100 FROM Types WHERE T_Name=’FRUIT’ D. DELET * FROM Types WHERE T_ID=100 AND T_Name=’FRUIT’ 13. 用_____语句修改表的一行或多行数据。( A ) A.Update B.set C.Select D.Where 14. 使用什么命令可以清除表中所有的内容? ( D ) A.INSERT B.UPDATE C. DELETE D.TRUNCATE 15.关于模式的描述下列哪一项不正确?( C ) A.表或索引等模式对象一定属于某一个模式 B.在Oracle数据库中,模式与数据库用户是一一对应的 C.一个表可以属于多个模式 D.一个模式可以拥有多个表 16.唯一约束与主键约束的一个区别是?( D ) A.唯一约束的列的值不可以有重复值 B.唯一约束的列的值可以不是唯一的 C.唯一约束的列不可以为空值 D.唯一约束的列可以为空值 17. 只能存储一个值的变量是哪种变量?( B ) A. 游标 B. 标量变量 C. 游标变量 D. 记录变量 18. 声明%TPYE类型的变量时,服务器将会做什么操作?( A ) A. 为该变量检索数据库列的数据类型 B.复制一个变量 C.检索数据库中的数据 D.为该变量检索列的数据类型和值 19.下列哪一项可以正确地引用该记录变量中的一个值?( B ) A.rec_abc(1) B. rec_abc(1).col C. rec_abc.col D.rec_abc.first() 20. 在定义游标时使用的FOR UPDATE子句的作用是______。( C ) A.执行游标 B. 执行SQL语句的UPDATE语句 C.对要更新表的列进行加锁 D. 都不对 21. 如果允许用户对视图进行更新和插入操作,但是又要防止用户将不符合视图约束条件的记录添加到视图,应当在定义视图时指定下列哪一个子句?( C ) A.WITH GRANT OPTION B. WITH READ ONLY C. WITH CHECK OPTION D. WITH CHECK ONLY 22. 如果想查看视图中哪些字段是可以更新的,应当查询哪一个数据字典视图?( D ) A. DBA_VIEWS B. DBA_OBJECTS C. DBA_CLU_COLUMNS D. DBA_UPDATABLE_COLUMNS 23. 在下列各选项中,关于序列的描述哪一项是不正确的?( D ) A. 序列是Oracle提供的用于产生一系列唯一数字的数据库对象 B.序列并不占用实际的存储空间 C.使用序列时,需要用到序列的两个伪列NEXTVAL与CURRVAL。其中,NEXTVAL 将返回序列生成的下一个值,而CURRVAL返回序列的当前值 D.在任何时候都可以使用序列的伪列CURRVAL,以返回当前序列值 24. 在下列各选项中,关于同义词的描述哪一项是不正确的?( B ) A.同义词是数据库对象的一个替代名,在使用同义词时,Oracle会将其翻译为对应的对象名称 B.在创建同义词时,所替代的模式对象必须存在 C.Oracle中的同义词分为公有同义词和私有同义词 D.公有同义词在数据库中所有的用户都可以使用;私有同义词由创建它的用户所拥有 25. 下列哪个锁模式不属于Oracle?( D ) A. 共享锁 B.排他锁 C. 行级共享锁 D. 死锁 26. 想在另一个模式中创建表,用户最少应该具有什么系统权限?( B ) A.CREATE TABLE B. CREATE ANY TABLE C. RESOURCE D. DBA 27. 如果要启用所有角色,则应该使用哪一个命令?( B ) A.SET ROLE ALL B. SET ROLE ENABLE ALL C. ALTER SESSION ALL D.ALTER USER ROLE ALL 28. 下列哪一个操作可以用来为一个备份操作手动分配通道?( A ) A.ALLOCATE CHANNEL B. CREATE CHANNEL C. CHANNEL ALLOCATE D. CREATE LINK 29. 下列哪一个命令用来显示RMAN通道的配置信息?( C ) A. LIST B. DISPLAY C.SHOW D.都可以 30. 下列哪一个命令可以用来执行不完全恢复?( B ) A. RESTORE DATABASE UNTIL B. RECOVER DATABASE UNTIL C. RECOVER DATA UNTIL D. RESTORE DATA UNTIL 三、简答 1. 说明数据库模式与用户之间的区别。 答案: 数据库模式与用户之间的区别在于:用户是数据库的使用者和管理者,用户具有帐户状态、访问权限和操作权限等属性。模式是一系列逻辑数据结构或对象的集合,是数据库中对象的组织和管理单位。 2. 简要游标的作用和游标操作的基本步骤。 答案: 游标的作用是将数据库的中数据检索出来后缓存,可以被PL/SQL程序一行一行的读取并处理。支持一条、多条、零条记录的处理。 游标的基本操作步骤为: (1)声明游标,使用查询来定义游标的列和行 (2)打开游标,使用PL/SQL命令OPEN来打开一个声明的游标 (3)提取数据,从游标中重复提取每条记录到数据结构中,直到数据集合被提交 (4)关闭游标,使用完游标后将其关闭 3.Oracle数据库的工作模式有哪两种?它们之间有有何区别? 答案: 在Oracle数据库中,数据库的操作模式分为专用服务器(DELICATED SERVER)模式和多线程服务器(MULTITHREADED SERVER)模式两种。其中,在专用服务器模式中为每个用户进程创建一个服务器进程,用户进程与服务器进程之间是1:1的关系;在共享服务器模式中,一个服务器进程可以为多个用户进程服务器。 4.说明数据库内存结构中SGA和PGA的组成,以及这两个内存区存放信息的区别。 答案: SGA区由数据缓冲区、共享池、重做日志缓冲区、大型池、JAVA池构成;PGA区由排序区、私有SQL区以及堆栈构成。SGA区是由Oracle分配的共享内存结构,包含一个数据库实例共享的数据和控制信息。当多个用户同时连接同一个实例时,SGA区数据供多个用户共享,所以SGA区又称为共享全局区。用户对数据库的各种操作主要在SGA区中进行。该内存区随数据库实例的创建而分配,随实例的终止而释放。PGA区是在用户进程连接数据库,创建一个会话时,由Oracle为用户分配的内存区域,保存当前用户私有的数据和控制信息,因此该区又称为私有全局区。每个服务器进程只能访问自己的PGA区,所有服务器进程PGA区总和即为实例的PGA区的大小。 5. 说明数据库表空间的种类,以及不同类型表空间的作用。 答案: 数据库表空间分为系统表空间和非系统表空间两类,其中非系统表空间包括撤销表空间、临时表空间和用户表空间等。 SYSTEM表空间主要用于存储数据库的数据字典、PL/SQL程序的源代码和解释代码、数据库对象的定义。撤销表空间专门进行回退信息的自动管理。临时表空间是专门进行临时段管理的表空间。用户表空间用于分离不同应用的数据,而且能够减少读取数据文件时产生的I/O冲突。 6. 说明Oracle 10g数据库文本初始化参数文件与服务器初始化参数文件的区别。 答案: 文本初始化参数文件是一个本地的初始化参数文件,而服务器初始化参数文件是一个放在数据库服务器端的共享的二进制初始化参数文件。文本参数文件的修改是通过直接对文本的修改实现的,通过命令行是无法将修改后的参数值写入该文件中,而服务器初始化参数文件是不能直接修改的,必须通过ALTER SYSTEM语句来进行参数修改的。 7. 简述PL/SQL程序结构及各个部分的作用。 答案: PL/SQL程序的基本单元是语句块,所有的PL/SQL程序都是由语句块构成的,语句块之间可以相互嵌套,每个语句块完成特定的功能。  声明部分:以关键字DECLARE开始,BEGIN结束。主要用于声明变量、常量、数据类型、游标、异常处理名称以及本地(局部)子程序定义等。  执行部分:是PL/SQL块的功能实现部分,以关键字BEGIN开始,EXCEPTION或END结束(如果PL/SQL块中没有异常处理部分,则以END结束)。该部分通过变量赋值、流程控制、数据查询、数据操纵、数据定义、事务控制、游标处理等实现块的功能。 异常处理部分:以关键字EXCEPTION开始,END结束。该部分用于处理该块执行过程中产生的异常。 8. 说明触发器的种类和对应的作用对象、触发事件。 答案: 触发器包括DML触发器、INSTEAD-OF触发器和系统触发器。其中,DML触发器主要作用于表,其事件有INSERT、UPDATE、DELETE;INSTEAD-OF触发器主要主用于视图,其事件有INSERT、UPDATE、DELETE;系统触发器主要是DML事件和系统事件发生时调用的触发器,其中DML事件包括CREATE、DROP、ALTER等,系统事件包括LOGON、LOGOFF、STARTUP、SHUTDOWN、SERVERERROR等。 9.简述Oracle数据库角色的种类、作用,以及如何利用角色为用户授权。 答案: Oracle数据库中角色分为系统预定义的角色和用户自定义的角色两类。角色是一系列权限的集合,可以先将权限授予角色,然后将角色授予具有相同权限的用户。 四、求解 现有关系数据库如下: S(SNO,SNAME,CITY) P(PNO,PNAME,COLOR,WEIGHT) J(JNO,JNAME,CITY) SPJ(SNO,PNO,JNO,QTY) 其中,S为供应商,包含属性的含义依次是供应商代码、供应商名字、供应商所在城市;P为零件,包含属性的含义依次是零件代码、零件名字、颜色、重量;J为工程项目,包含属性的含义依次是工程项目代码、工程项目名字、工程项目所在城市;SPJ为供货关系,包含属性的含义依次是供应商代码、零件代码、工程项目代码,某供应商向某个项目供应数量的零件数量。 请用SQL语言完成如下问: (1)查询供应工程J1零件P1的供应商号码SNO (2)查询供应工程J1零件为红色的供应商号码SNO (3)查询没有使用北京供应商生产的红色零件的工程号JNO 五、设计(E-图) 六、PL/SQL语言程序设计。 设学校环境如下:一个系有若干个专业,每个专业一年只招一个班,每个班有若干个学生: 现要建立关于系、学生、班级的数据库,关系模式为: 班CLASS(班号classid,专业名subject,系名deptname,入学年份enrolltime,人数num) 学生STUDENT(学号studentid,姓名name,年龄age,班号classid) 系DEPARTMENT(系号deptid,系名deptname) 试用PL/SQL语言完成以下功能: 1. 建表,在定义中要求声明: (1) 每个表的主外键。 (2) 每个班级的人数不能超过30人。 (3) 学生的年龄介于15到40岁之间。 (4) 学生姓名不能为空。 2. 插入如下数据 CLASS表 classid subject deptname enrolltime num 101 软件 计算机 1995 20 102 微电子 计算机 1996 30 111 无机化学 化学 1995 29 112 高分子化学 化学 1996 25 121 统计数学 数学 1995 20 131 现代语言 中文 1996 20 141 国际贸易 经济 1997 30 142 国际金融 经济 1996 14 STUDENT表 studentid name age classid 8101 张三 18 101 8102 钱四 16 121 8103 王玲 17 131 8105 李飞 19 102 8109 赵四 18 141 8110 李可 20 142 8201 张飞 18 111 8302 周瑜 16 112 8203 王亮 17 111 8305 董庆 19 102 8409 赵龙 18 101 8510 李丽 20 142 DEPARTMENT表 deptid deptname 001 数学 002 计算机 003 化学 004 中文 005 经济 3. 学校又新增加了一个物理系,编号为006 4. 学生张三退学,请更新相关的表。 1、有一张表test,有3个字段id,name,parentid。parentid是指父亲的id,请写一个sql语句,找出当过爷爷的id和name。 2、有一张学生表student,字段有student_id,name,即学号,名字。 还有一张选课表,字段有student_id,lesson_id。 还有一张课程表,字段lesson_id,lesson_name。 学生和课程是多对多的关系。 写一个sql语句,找出所有选了全部课程的学生。 3、有一张表person表,字段有id,name,age。age是年龄。 写一个sql语句,找出年龄最接近的2个人。 如有下面4条记录: 1,a,18 2,b,20 3,c,25 4,d,26 则输出3,4 emp表和dept表完成下列练习 Emp员工表 empno ename job Mgr Hiredate Sal Comm Deptno 员工号 员工姓名 工作 上级编号 受雇日期 薪金 佣金 部门编号 Dept表 Deptno Dname Loc 部门编号 部门名称 地点 1.列出至少有一个员工的所有部门。 select dept_id from s_emp where userid is not null; 2.列出薪金比“chad”多的所有员工。 select id,salary from s_emp where salary>(select salary from s_emp where first_name='Chad'); 3.列出所有员工的姓名及其直接上级的姓名。 select l.first_name as yuangong,e.first_name as laoban from s_emp e,s_emp l where e.manager_id=l.id(+); 4.列出受雇日期早于其直接上级的所有员工。 select l.first_name as yuangong,e.first_name as laoban from s_emp e,s_emp l where e.manager_id=l.id(+) and l.start_date>e.start_date; 5.列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。 6.列出所有“CLERK”(办事员)的姓名及其部门名称。 7.列出最低薪金大于1500的各种工作。 8.列出在部门“SALES”(销售部)工作的员工的姓名,假定不知道销售部的部门编号。 9.列出薪金高于公司平均薪金的所有员工。 10.列出与“SCOTT”从事相同工作的所有员工。 11.列出薪金等于部门30中员工的薪金的所有员工的姓名和薪金。 12.列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金。 13.列出在每个部门工作的员工数量、平均工资和平均服务期限。 14.列出所有员工的姓名、部门名称和工资。 15.列出从事同一种工作但属于不同部门的员工的一种组合。 16.列出所有部门的详细信息和部门人数。 17.列出各种工作的最低工资。 18.列出各个部门的MANAGER(经理)的最低薪金。 19.列出所有员工的年工资,按年薪从低到高排序。 原文:http://www.2xyd.cn/showtopic-524.aspx Oracle二附答案 使用scott/tiger的emp表完成练习 更多编程相关:http://www.2xyd.cn/showforum-11.aspx 答案: 1. select distinct dname from dept where deptno in (select distinct deptno from emp); 要查部门编号如果存在于emp 表中,说明这个部门有员工。 2. select ename,job,mgr,hiredate,sal from emp where sal> (select sal from emp where ename='SMITH'); 3. select e.ename, e.mgr , w.ename from emp e, emp w where e.mgr=w.empno; 4. select e.ename, e.mgr , e.hiredate,w.ename,w.hiredate from emp e, emp w where e.mgr=w.empno and e.hiredate< w.hiredate; 5. select e.ename,e.hiredate, d.dname,d.deptno from emp e, dept d where e.deptno (+)=d.deptno; 本例子使用的是外连接, 也可以用右连接。 select e.ename,e.hiredate, d.dname,d.deptno from emp e right join dept d on e.deptno=d.deptno; 6. select e.ename,e.hiredate,e.job, d.dname,d.deptno from emp e, dept d where e.deptno =d.deptno and e.job=upper('clerk'); 7. select job, min(sal) from emp group by job having min(sal)>1500; 8. select e.ename,d.dname from emp e,dept d 2楼 where e.deptno=d.deptno and d.dname=upper('sales'); 或者: select ename from emp where deptno = (select deptno from dept where dname=upper('SALES')); 9. select ename, job, sal from emp where sal> (select avg(sal) from emp ); 10. select ename, job from emp where job = (select job from emp where ename=upper('scott')); 11. select ename, sal,job from emp where sal in (select sal from emp where deptno=30); 12. select ename, sal,job from emp where sal >all (select sal from emp where deptno=30); 或者 select ename ,sal from emp where sal> (select max(sal) from emp where deptno=30); 13. select d.deptno,d.dname, count(e.ename), avg(e.sal), avg(months_between(sysdate,e.hiredate)) from emp e, dept d where e.deptno(+)= d.deptno group by d.deptno,dname; 或者下面的方法,这种方法更好理解,把需要汇总的生成一个视图e。 select e.*,d.dname , from (select deptno, count(ename) ,avg(sal),avg(months_between(sysdate,hiredate)) from emp group by deptno) e, dept d where e.deptno =d.deptno; 14. select d.dname, e.ename, sal+nvl(comm,0) from emp e, dept d where d.deptno=e.deptno; 15. select e.ename,e.job, e.deptno ,d.job, d.deptno from emp e, emp d where e.job=d.job and e.deptno<>d.deptno; 16. select count(e.ename),d.dname from emp e, dept d where e.deptno(+)= d.deptno group by e.deptno,d.dname; 或者写成 select d.deptno,e.*,d.dname from (select deptno,count(ename) from emp group by deptno) e,dept d where e.deptno(+)= d.deptno; 17. select job,min(sal+nvl(comm,0))from emp group by job; 18. select deptno,min(sal) from emp where job=upper('manager') group by deptno ; 19. select ename , (sal+nvl(comm,0))*12 yearsal from emp order by yearsal ; --1、列出至少有一个雇员的所有部门   select distinct dname from dept where deptno in (select distinct deptno from emp);   --2、列出薪金比"SMITH"多的所有雇员   select ename,sal from emp where sal>(select sal from emp where ename=upper('smith'));   --3、列出所有雇员的姓名及其直接上级的姓名   select e.ename,m.ename from emp e,emp m where e.mgr=m.empno(+);   --4、列出入职日期早于其直接上级的所有雇员   select ename from emp e where hiredate<(select hiredate from emp where empno=e.mgr);   --5、列出部门名称和这些部门的雇员,同时列出那些没有雇员的部门   select dname,ename from dept d left join emp e on d.deptno=e.deptno;   --6、列出所有“CLERK”(办事员)的姓名及其部门名称   select ename,dname from emp e left join dept d on e.deptno=d.deptno where job=upper('clerk');   --7、列出各种工作类别的最低薪金,显示最低薪金大于1500的记录   select job,min(sal) from emp group by job having min(sal)>1500;   --8、列出从事“SALES”(销售)工作的雇员的姓名,假定不知道销售部的部门编号   select ename from emp where deptno = (select deptno from dept where dname=uppder('SALES'))   --9、列出薪金高于公司平均水平的所有雇员   select ename from emp where sal>(select avg(sal) from emp);   --10、列出与“SCOTT”从事相同工作的所有雇员   select ename from emp where job=(select job from emp where ename=upper('scott'));   --11、列出某些雇员的姓名和薪金,条件是他们的薪金等于部门30中任何一个雇员的薪金   select ename,sal from emp where sal in (select sal from emp where deptno=30);   --12、列出某些雇员的姓名和薪金,条件是他们的薪金高于部门30中所有雇员的薪金   select ename ,sal from emp where sal>(select max(sal) from emp where deptno=30);   --13、列出每个部门的信息以及该部门中雇员的数量   select d.deptno,dname,count(ename) from dept d left join emp e on (d.deptno=e.deptno)   group by d.deptno,dname   --14、列出所有雇员的雇员名称、部门名称和薪金   Select e.ename,d.dname,e.sal from emp e left join dept d on (d.deptno=e.deptno)   --15、列出从事同一种工作但属于不同部门的雇员的不同组合   Select tba.ename,tbb.ename,tba.job,tbb.job,tba.deptno,tba.deptno   From emp tba,emp tbb   Where tba.job=tbb.job and tba.deptno<>tbb.deptno   --16、列出分配有雇员数量的所有部门的详细信息,即使是分配有0个雇员   Select dept.deptno,dname,loc,count(empno)   From dept,emp   Where dept.deptno=emp.deptno(+)   Group by dept.deptno,dname,loc   --17、列出各种类别工作的最低工资   Select min(sal) from emp group by job   --18、列出各个部门的MANAGER(经理)的最低薪金   Select deptno,min(sal) from emp where job=upper(‘manager’) group by deptno   --19、列出按年薪排序的所有雇员的年薪   select (sal+nvl(comm,0))*12 as avn from emp order by avn   --20、列出薪金水平处于第四位的雇员   Select * from (Select ename,sal, rank() over (order by sal desc) as grade from emp) where grade=4 --1、选择部门30中的雇员   select * from emp where deptno=30;   --2、列出所有办事员的姓名、编号和部门   select ename,empno,dname from emp e inner join dept d on e.deptno = d.deptno where job=upper(‘clerk’);   --3、找出佣金高于薪金的雇员   select * from emp where comm>sal;   --4、找出佣金高于薪金60%的雇员   select * from emp where comm>sal*0.6   --5、找出部门10中所有经理和部门20中的所有办事员的详细资料   select * from emp where (deptno=10 and job=upper(‘manager‘)) or (deptno=20 and job=upper(‘clerk ‘));   --6、找出部门10中所有经理、部门20中所有办事员,既不是经理又不是办事员但其薪金>=2000的所有雇员的详细资料   select * from emp where (deptno=10 and job=upper(‘manager‘)) or (deptno=20 and job=upper(‘clerk ‘)) or (job<>upper(‘manager’) and job<>upper(‘clerk’) and sal>=2000)   --7、找出收取佣金的雇员的不同工作   select distinct job from emp where comm>0;   --8、找出不收取佣金或收取的佣金低于100的雇员   select * from emp where nvl(comm,0)<100;   --9、找出各月最后一天受雇的所有雇员   select * from emp where hiredate= last_day(hiredate);   --10、找出早于25年之前受雇的雇员   select * from emp where months_between(sysdate,hiredate)/12>25;   select * from emp where hiredate<add_months(sysdate,-12*25);   --11、显示只有首字母大写的所有雇员的姓名   select ename from emp where ename=initcap(ename);   --12、显示正好为6个字符的雇员姓名   select ename from emp where length(ename)=6   --13、显示不带有‘R‘的雇员姓名   Select ename from emp where ename not like ‘%R%’;   Select ename from emp where instr(ename,’R’)=0;   --14、显示所有雇员的姓名的前三个字符   select substr(ename,1,3) from emp   --15、显示所有雇员的姓名,用a替换所有‘A‘   Select replace(ename,’A’,’a’) from emp   --16、显示所有雇员的姓名以及满10年服务年限的日期   Select ename,add_months(hiredate,12*10) ‘服务年限的日期’ from emp   --17、显示雇员的详细资料,按姓名排序   Select * from emp order by ename   --18、显示雇员姓名,根据其服务年限,将最老的雇员排在最前面   Select ename from emp order by hiredate   --19、显示所有雇员的姓名、工作和薪金,按工作的降序顺序排序,而工作相同时按薪金升序   Select ename,job,sal from emp order by job desc ,sal asc   --20、显示所有雇员的姓名和加入公司的年份和月份,按雇员受雇日所在月排序,将最早年份的项目排在最前面   select ename,to_char(hiredate,‘yyyy‘),to_char(hiredate,‘mm‘) from emp order by hiredate asc   --21、显示在一个月为30天的情况下所有雇员的日薪金   select ename,sal/30 from emp;   --22、找出在(任何年份的)2月受聘的所有雇员   select * from emp where to_char(hiredate,‘mm‘)=‘02‘;   --23、对于每个雇员,显示其加入公司的天数   select ename,sysdate-hiredate from emp   --24、显示姓名字段的任何位置,包含 "A" 的所有雇员的姓名   select ename from emp where ename like ‘%A%‘;   select ename from emp where instr(ename,’A’,1)>0;   --25、以年、月和日显示所有雇员的服务年限   Select months_between(sysdate,hiredate)/12 as “年”, months_between(sysdate,hiredate) as “月”, sysdate-hiredate as “日” from emp
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值