Oracle练习题概要.docx

上传人:b****6 文档编号:15431025 上传时间:2023-07-04 格式:DOCX 页数:25 大小:27.15KB
下载 相关 举报
Oracle练习题概要.docx_第1页
第1页 / 共25页
Oracle练习题概要.docx_第2页
第2页 / 共25页
Oracle练习题概要.docx_第3页
第3页 / 共25页
Oracle练习题概要.docx_第4页
第4页 / 共25页
Oracle练习题概要.docx_第5页
第5页 / 共25页
Oracle练习题概要.docx_第6页
第6页 / 共25页
Oracle练习题概要.docx_第7页
第7页 / 共25页
Oracle练习题概要.docx_第8页
第8页 / 共25页
Oracle练习题概要.docx_第9页
第9页 / 共25页
Oracle练习题概要.docx_第10页
第10页 / 共25页
Oracle练习题概要.docx_第11页
第11页 / 共25页
Oracle练习题概要.docx_第12页
第12页 / 共25页
Oracle练习题概要.docx_第13页
第13页 / 共25页
Oracle练习题概要.docx_第14页
第14页 / 共25页
Oracle练习题概要.docx_第15页
第15页 / 共25页
Oracle练习题概要.docx_第16页
第16页 / 共25页
Oracle练习题概要.docx_第17页
第17页 / 共25页
Oracle练习题概要.docx_第18页
第18页 / 共25页
Oracle练习题概要.docx_第19页
第19页 / 共25页
Oracle练习题概要.docx_第20页
第20页 / 共25页
亲,该文档总共25页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

Oracle练习题概要.docx

《Oracle练习题概要.docx》由会员分享,可在线阅读,更多相关《Oracle练习题概要.docx(25页珍藏版)》请在冰点文库上搜索。

Oracle练习题概要.docx

Oracle练习题概要

一、填空

1.在多进程Oracle实例系统中,进程分为用户进程、后台进程和服务进程。

2.标准的SQL语言语句类型可以分为:

数据定义语句(DDL)、数据操纵语句(DML)和数据控制语句(DCL)。

3.在需要滤除查询结果中重复的行时,必须使用关键字Distinct;在需要返回查询结果中的所有行时,可以使用关键字ALL。

4.当进行模糊查询时,应使用关键字like和通配符问号(?

)或百分号"%"。

5.Where子句可以接收From子句输出的数据,而HAVING子句则可以接收来自WHERE、FROM或GROUPBY子句的输入。

6.在SQL语句中,用于向表中插入数据的语句是Insert。

7.如果需要向表中插入一批已经存在的数据,可以在INSERT语句中使用Select语句。

8.使用Describe命令可以显示表的结构信息。

9.使用SQL*Plus的Get命令可以将文件检索到缓冲区,并且不执行。

10.使用Save命令可以将缓冲区中的SQL命令保存到一个文件中,并且可以使用Run命令运行该文件。

11.一个模式只能够被一个数据库对象所拥有,其创建的所有模式对象都保存在自己的模式中。

12.根据约束的作用域,约束可以分为表级约束和列级约束两种。

列级约束是字段定义的一部分,只能够应用在一个列上;而表级约束的定义独立于列的定义,它可以应用于一个表中的多个列。

13.填写下面的语句,使其可以为Class表的ID列添加一个名为PK_CLASS_ID的主键约束。

ALTERTABLEClass

Add____________PK_LASS_ID(Constraint)

PRIMARYKEY________(ID)

14.每个Oracle10g数据库在创建后都有4个默认的数据库用户:

system、sys、sysman和DBcnmp

 

15.Oracle提供了两种类型的权限:

系统权限和对象权限。

系统权限提供了在Oracle数据库系统范围内执行某种任务的操作能力,而对象权限则是一种赋予用户在指定的数据库对象(如表、视图、过程等)

 

16.Oralce数据库在进行物理备份有联机备份和脱机备份两种方式可供选择。

.

17.从存储结构的角度来说,Oracle数据库可分为物理结构和逻辑结构。

18.表空间是Oracle数据库中数据的逻辑组织,每个数据库至少有一个SYSTEM系统表空间。

19.视图是一个表示表的数据的数据库对象,它允许用户从一个表或一组表中通过一定的查询语句建立一个“虚表”。

20.序列是一种可被多个用户使用的用于产生一系列唯一数字的数据库对象。

尤其适合多用户环境中,可以生成唯一的序列号而没有磁盘I/O或事务处理锁定开销。

21.一个表空间具有离线(OFFLINE)、在线(ONLINE)、只读(READONLY)、读写(READWRITE)状态。

二、选择

1.在全局存储区SGA中,哪部分内存区域是循环使用的?

(B)

A.数据缓冲区B.日志缓冲区C.共享池D.大池

2.如果一个服务器进程非正常终止,Oracle系统将使用下列哪一个进程来释放它所占用的资源?

(D)

A.DBWRB.LGWRC.SMOND.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.Orderby子句

7.Having子句的作用是(B)。

a.查询结果的分组条件

B.组的筛选条件

C.限定返回的行的判断条件

D.对结果集进行排序

8.下列哪个函数可以把一个列中的所有值相加求和?

(B)

AMAXB.SUMC.COUNTD.AVG

9.下列哪个子句是SELECT语句中必选项?

(A)

A.FROMB.WHEREC.HAVINGD.ORDERBY

10.下列哪个子句实现对一个结果集进行分组和汇总?

(D)

A.HAVINGB.ORDERBYC.WHERED.GROUPBY

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.INSERTINTOTypeValues(100,‘FRUIT’)

B.SELECT*FROMTypeWHERET_ID=100ANDT_NAME=’FRUIT’

C.UPDATESETT_ID=100FROMTypesWHERET_Name=’FRUIT’

D.DELET*FROMTypesWHERET_ID=100ANDT_Name=’FRUIT’

13.用_____语句修改表的一行或多行数据。

(A)

A.UpdateB.setC.SelectD.Where

14.使用什么命令可以清除表中所有的内容?

(D)

A.INSERTB.UPDATEC.DELETED.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.colD.rec_abc.first()

20.在定义游标时使用的FORUPDATE子句的作用是______。

(C)

A.执行游标B.执行SQL语句的UPDATE语句

C.对要更新表的列进行加锁D.都不对

21.如果允许用户对视图进行更新和插入操作,但是又要防止用户将不符合视图约束条件的记录添加到视图,应当在定义视图时指定下列哪一个子句?

(C)

A.WITHGRANTOPTION

B.WITHREADONLY

C.WITHCHECKOPTION

D.WITHCHECKONLY

22.如果想查看视图中哪些字段是可以更新的,应当查询哪一个数据字典视图?

(D)

A.DBA_VIEWSB.DBA_OBJECTSC.DBA_CLU_COLUMNSD.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.CREATETABLEB.CREATEANYTABLEC.RESOURCED.DBA

27.如果要启用所有角色,则应该使用哪一个命令?

(B)

A.SETROLEALLB.SETROLEENABLEALL

C.ALTERSESSIONALLD.ALTERUSERROLEALL

28.下列哪一个操作可以用来为一个备份操作手动分配通道?

(A)

A.ALLOCATECHANNELB.CREATECHANNELC.CHANNELALLOCATE

D.CREATELINK

29.下列哪一个命令用来显示RMAN通道的配置信息?

(C)

A.LISTB.DISPLAYC.SHOWD.都可以

30.下列哪一个命令可以用来执行不完全恢复?

(B)

A.RESTOREDATABASEUNTIL

B.RECOVERDATABASEUNTIL

C.RECOVERDATAUNTIL

D.RESTOREDATAUNTIL

 

三、简答题

1.说明数据库模式与用户之间的区别。

答案:

数据库模式与用户之间的区别在于:

用户是数据库的使用者和管理者,用户具有帐户状态、访问权限和操作权限等属性。

模式是一系列逻辑数据结构或对象的集合,是数据库中对象的组织和管理单位。

2.简要游标的作用和游标操作的基本步骤。

答案:

游标的作用是将数据库的中数据检索出来后缓存,可以被PL/SQL程序一行一行的读取并处理。

支持一条、多条、零条记录的处理。

游标的基本操作步骤为:

(1)声明游标,使用查询来定义游标的列和行

(2)打开游标,使用PL/SQL命令OPEN来打开一个声明的游标

(3)提取数据,从游标中重复提取每条记录到数据结构中,直到数据集合被提交

(4)关闭游标,使用完游标后将其关闭

3.Oracle数据库的工作模式有哪两种?

它们之间有有何区别?

答案:

在Oracle数据库中,数据库的操作模式分为专用服务器(DELICATEDSERVER)模式和多线程服务器(MULTITHREADEDSERVER)模式两种。

其中,在专用服务器模式中为每个用户进程创建一个服务器进程,用户进程与服务器进程之间是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.说明Oracle10g数据库文本初始化参数文件与服务器初始化参数文件的区别。

答案:

文本初始化参数文件是一个本地的初始化参数文件,而服务器初始化参数文件是一个放在数据库服务器端的共享的二进制初始化参数文件。

文本参数文件的修改是通过直接对文本的修改实现的,通过命令行是无法将修改后的参数值写入该文件中,而服务器初始化参数文件是不能直接修改的,必须通过ALTERSYSTEM语句来进行参数修改的。

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.列出至少有一个员工的所有部门。

selectdept_idfroms_empwhereuseridisnotnull;

2.列出薪金比“chad”多的所有员工。

selectid,salaryfroms_empwheresalary>(selectsalaryfroms_empwherefirst_name='Chad');

3.列出所有员工的姓名及其直接上级的姓名。

selectl.first_nameasyuangong,e.first_nameaslaobanfroms_empe,s_emplwheree.manager_id=l.id(+);

4.列出受雇日期早于其直接上级的所有员工。

selectl.first_nameasyuangong,e.first_nameaslaobanfroms_empe,s_emplwheree.manager_id=l.id(+)andl.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.列出所有员工的年工资,按年薪从低到高排序。

原文:

Oracle习题二附答案使用scott/tiger的emp表完成练习

更多编程相关:

答案:

1.

selectdistinctdname

fromdept

wheredeptnoin

          (selectdistinctdeptno

           fromemp);

要查部门编号如果存在于emp表中,说明这个部门有员工。

2.

selectename,job,mgr,hiredate,sal

fromemp

wheresal>

        (selectsal

         fromemp

         whereename='SMITH');

3.

selecte.ename,e.mgr,w.ename

fromempe,empw

wheree.mgr=w.empno;

4.

selecte.ename,e.mgr,e.hiredate,w.ename,w.hiredate

fromempe,empw

wheree.mgr=w.empno

ande.hiredate

5.

selecte.ename,e.hiredate,d.dname,d.deptno

fromempe

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 求职职场 > 简历

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2