oracle 数据文件、表空间、日志文件、控制文件数据库管理
orcl复习重点部分
第一章1.简要说明例程与数据库之间的联系和区别?ORACLE数据库是安装在磁盘上的ORACLE数据库文件和相关的数据库管理系统的集合。
磁盘上比较重要的文件包括数据文件,控制文件,重做日志文件,初始化参数文件,口令文件,归档重做日志文件。
例程是由在内从中的一组后台进程和内存结构组成。
2.说明数据库、表空间和数据文件之间的关系?ORACLE数据库的逻辑结构和物理结构的对应关系,一个ORACLE数据库可以拥有多个表空间,每个表空间有多个段组成,每个段由若干个区间组成,每个区间包含多个ORACLE 数据块,每个ORACLE数据块包含多个OS屋里磁盘快。
表空间有多个物理文件支持,具体存储表空间中的个对象。
3.比较表和视图二者间的异同?视图中没有数据,仅仅是一条SQL语句,查询语句检索出来的数据以表的形式表示;视图的定义存储在数据字典中,视图的查询基于表;视图没有直接的相关物理数据,不能像表那样被索引。
第二章1.写出以scott用户登录到数据库orcl,然后查看该用户可以访问的表,视图的相关命令?CONN scott/tiger@orclSELECT * FROM tab;2.设置查询结果的显示格式:每页24行,每行100个字符,SAL列的显示格式为¥99.990.0. SET PAGESIZE 24SET LINESIZE 100COLUMN sal FORMAT $99,990.00第三章1.写出查看某个用户说有用的角色的SQL语句。
CONN stu01/stu01pwd@orclCOLUMN USERNAME FORMAT A10SELECT username,granted_role FROM user_role_privs;2.写出查询当前用户将哪些表的访问权限授予给其他用户的SQL语句。
CONN scott/tiger@orclCOLUMN GRANTEE FORMAT A10SELECT grantee,table_name,grantor,privilege,grantableFROM user_tab_privs_made;3.以系统管理员的身份登录,在SQL*plus中查询各用户获得的系统特权和角色。
基础概念:Oracle数据库、实例、用户、表空间、表之间的关系
基础概念:Oracle数据库、实例、用户、表空间、表之间的关系数据库:Oracle数据库是数据的物理存储。
这就包括(数据文件ORA或者DBF、控制文件、联机日志、参数文件)。
其实Oracle数据库的概念和其它数据库不一样,这里的数据库是一个操作系统只有一个库。
可以看作是Oracle就只有一个大数据库。
实例:一个Oracle实例(Oracle Instance)有一系列的后台进程(Backguound Processes)和内存结构(Memory Structures)组成。
一个数据库可以有n个实例。
用户:用户是在实例下建立的。
不同实例可以建相同名字的用户。
表空间:表空间是一个用来管理数据存储逻辑概念,表空间只是和数据文件(ORA或者DBF文件)发生关系,数据文件是物理的,一个表空间可以包含多个数据文件,而一个数据文件只能隶属一个表空间。
数据文件(dbf、ora):数据文件是数据库的物理存储单位。
数据库的数据是存储在表空间中的,真正是在某一个或者多个数据文件中。
而一个表空间可以由一个或多个数据文件组成,一个数据文件只能属于一个表空间。
一旦数据文件被加入到某个表空间后,就不能删除这个文件,如果要删除某个数据文件,只能删除其所属于的表空间才行。
注:表的数据,是有用户放入某一个表空间的,而这个表空间会随机把这些表数据放到一个或者多个数据文件中。
由于oracle的数据库不是普通的概念,oracle是有用户和表空间对数据进行管理和存放的。
但是表不是有表空间去查询的,而是由用户去查的。
因为不同用户可以在同一个表空间建立同一个名字的表!这里区分就是用户了!关系示意图:理解1:Oracle数据库可以创建多个实例,每个实例可以创建多个表空间,每个表空间下可以创建多个用户(同时用户也属于表空间对应的实例)和数据库文件,用户可以创建多个表(每个表随机存储在一个或多个数据库文件中),如下图:理解2:理解1MS有误。
实例下有和,授权访问,是管理的,经授权在中创建,随机存储到不同的中。
oracle下的数据库实例、表空间、用户及其表的区分
oracle下的数据库实例、表空间、⽤户及其表的区分完整的Oracle数据库通常由两部分组成:Oracle数据库和数据库实例。
1) 数据库是⼀系列物理⽂件的集合(数据⽂件,控制⽂件,联机⽇志,参数⽂件等);2) Oracle数据库实例则是⼀组Oracle后台进程/线程以及在服务器分配的共享内存区。
在启动Oracle数据库服务器时,实际上是在服务器的内存中创建⼀个Oracle实例(即在服务器内存中分配共享内存并创建相关的后台内存),然后由这个Oracle数据库实例来访问和控制磁盘中的数据⽂件。
Oracle有⼀个很⼤的内存快,成为全局区(SGA)。
⼀、数据库、表空间、数据⽂件1、数据库数据库是数据集合。
Oracle是⼀种数据库管理系统,是⼀种关系型的数据库管理系统。
通常情况了我们称的“数据库”,并不仅指物理的数据集合,他包含物理数据、数据库管理系统。
也即物理数据、内存、操作系统进程的组合体。
我们在安装Oracle数据库时,会让我们选择安装启动数据库(即默认的全局数据库)如下图:全局数据库名:就是⼀个数据库的标识,在安装时就要想好,以后⼀般不修改,修改起来也⿇烦,因为数据库⼀旦安装,数据库名就写进了控制⽂件,数据库表,很多地⽅都会⽤到这个数据库名。
启动数据库:也叫全局数据库,是数据库系统的⼊⼝,它会内置⼀些⾼级权限的⽤户如SYS,SYSTEM等。
我们⽤这些⾼级权限账号登陆就可以在数据库实例中创建表空间,⽤户,表了。
查询当前数据库名:select name from v$database;2、数据库实例⽤Oracle官⽅描述:实例是访问Oracle数据库所需的⼀部分计算机内存和辅助处理后台进程,是由进程和这些进程所使⽤的内存(SGA)所构成⼀个集合。
其实就是⽤来访问和使⽤数据库的⼀块进程,它只存在于内存中。
就像Java中new出来的实例对象⼀样。
我们访问Oracle都是访问⼀个实例,但这个实例如果关联了数据库⽂件,就是可以访问的,如果没有,就会得到实例不可⽤的错误。
数据库存储设置与管理
• 创建一个永久性的表空间HRTBS4,区定制
分配,段采用手动管理方式。
– CREATE TABLESPACE HRTBS4 DATAFILE
– 'D:\APP\ADMINISTRATOR\ORADATA\HUMAN_RESOURCE\
– HRTBS4_1.DBF' SIZE 50M
– EXTENT MANAGEMENT LOCAL UNIFORM SIZE 512K
• Oracle数据库物理存储结构
精品课件
4
• 数据文件:用于存储数据库中的所有数据; • 控制文件:用于记录和描述数据库的物理存储
结构信息; • 重做日志文件:用于记录外部程序对数据库的
改变操作; • 归档文件:用于保存已经写满的重做日志文件; • 初始化参数文件:用于设置数据库启动时的参
数初始值; • 跟踪文件:用于记录用户进程、数据库后台进
– INDEX01.DBF' SIZE 50M;
精品课件
13
创建大文件表空间
• 一个大文件表空间只包含一个数据文件, 该数据文件可以包含4G(232)个数据块。
• 通过查询数据字典DATABASE_PROPERTIES中 数据库的属性DEFAULT_TBS_TYPE,可以知 道数据库默认创建的是小文件表空间还是 大文件表空间。
精品课件
14
• 创建一个大文件表空间,文件大小为1G,区 的分配采用定制方式。
– CREATE BIGFILE TABLESPACE big_tbs DATAFILE – 'D:\APP\ADMINISTRATOR\ORADATA\ORCL\big01.dbf' – SIZE 1G UNIFORM SIZE 512K;
oracle 数据库物理结构
数据文件和表空间有着密切的关系,Oracle 数据 库至少要包含一个数据文件,并且数据文件是表 空间的物理组成元素,一个表空间可以包含多个 数据文件,并且每个数据文件只能惟一地属于某 个表空间。 关于“表空间”在后面会给大家详细介绍。
但如果执行介质恢复(例如数据文件意外丢失) ,则必须要用到归档日志。归档日志是非活 动重做日志的备份,数据库只有处于 ARCHIVELOG 模式时才会生成归档日志,并且 每次日志切换都会生成归档日志。
如图所示:
假定数据库只包含两个日志组,并且处于 ARCHIVELOG 模式。初始阶段LGWR 会将事务 变化写入到日志组一,当日志组一写满之后 ,LGWR 会将事务变化写入到日志组二中, 并且会促使ARCn 进程将日志组一的内容保存 到归档日志中,依此类推。
2.6.1 连接和建立会话
当客户应用需要执行SQL 语句时,首先要建立用户进程 ,同时在服务器端会自动为该用户进程派生一个新的 服务进程。默认情况下,用户进程与服务器进程是一 一对应的关系。 当客户端运行SQL 语句时,用户进程会通过网络将该 SQL 语句发送到对应的服务进程,并且由服务进程执行 该SQL 语句,服务器进程在执行了SQL 语句之后,会将 SQL 语句的结果通过网络返回到用户进程。
2.5.3 区(Extents)
数据区间简称为区,区是为段分配空间的逻辑单位 ,Oracle 在分配空间时,并不是以块为单位进行的 ,而是将多个连续的块一次性的分配给数据库对象 。这些连续的块在回收存储
空间时,也一起回收。这些连续的数据块就是数据 区间。 当创建一个数据库对象时,Oracle为这些对象创建一 个段,并分配初始区。当段中的初始区的存储空间 使用完毕后,Oracle会为段自动分配新的区,每个区 的大小不要求相同
描述oracle数据库体系结构的组成及其关系。
描述oracle数据库体系结构的组成及其关系。
Oracle数据库体系结构由以下几个部分组成:1. 实例(Instance):实例是在计算机内存中运行的一个进程,负责管理数据库的操作。
每个实例都有自己的内存空间和进程,可以同时运行多个实例。
2. 数据库(Database):数据库是一个存储数据的容器,包含了表、视图、索引等对象。
一个实例可以管理多个数据库,每个数据库由一个或多个数据文件组成。
3. 数据文件(Data File):数据文件是用来存储数据库的实际数据的文件,包含了表、索引等对象的数据。
一个数据库可以有多个数据文件,每个数据文件具有独立的文件名和路径。
4. 控制文件(Control File):控制文件是用来记录数据库的结构和状态信息的文件,包括数据库名、数据文件的路径、表空间的信息等。
一个数据库通常有一个或多个控制文件。
5. 日志文件(Redo Log File):日志文件是用来记录数据库的变化操作的文件,包括数据更改、事务回滚等。
日志文件用于实现数据库的恢复和数据的一致性。
每个数据库通常有多个日志文件。
6. 表空间(Tablespace):表空间是数据库中逻辑数据存储的单位,用来管理和组织对象。
每个表空间由一个或多个数据文件组成,不同表空间可以包含不同的数据对象。
7. 段(Segment):段是逻辑存储结构的基本单位,是指数据库中的一个连续空间。
每个表、索引等对象都占用一个或多个段。
8. 区(Extent):区是段的扩展单位,是一组连续的数据块。
一个段由多个区组成。
9. 块(Data Block):块是数据库存储的最小单位,通常是8KB大小。
每个数据文件由多个块组成。
以上组成部分之间的关系如下:- 实例与数据库:一个实例可以管理多个数据库,每个数据库都有自己的实例。
- 数据库与数据文件:一个数据库可以由一个或多个数据文件组成,每个数据文件存储数据库的实际数据。
- 实例与控制文件:一个实例通常有一个或多个控制文件,控制文件记录了数据库的结构和状态信息。
《Oracle数据库应用与实践》课后习题参考答案
第 5 章 Oracle 模式对象
一、填空题
1. 字段级约束 表约束
2. NOT NULL 约束 UNIQUE 约束 PRIMARY KEY 约束
束
3. CREATE TABLE
CREATE ANY TABLE
4. UNIQUE PRIMARY KEY CHECK
5. 合并索引 重建索引
6. user_updatable_columns
一、 填空题 1. 数据挖掘 隐含的 未知的 2. API-ODM Java API ODM DBMS_DM PL/SQL API
3. Clustering Association Feature Extraction
Oracle 数据库应用与实践
2、某 cc 表数据如下: c1 c2 -------------1西 1安 1的 2天 2气
Oracle 数据库应用与实践
3好 …… 转换为 1 西安的 2 天气 3好 要求:不能改变表结构及数据内容,仅在最后通过 SELECT 显示出这个查询结果
代码为: create or replace function x return varchar2 is type t_array is table of number index by binary_integer; type tarray is table of varchar2(10) index by binary_integer; ta t_array; tar tarray; re varchar2(10); n number; na varchar2(10); begin select id bulk collect into ta from (select id,name from xx order by id) group by id; for i in st loop dbms_output.put(ta(i)||' '); select name bulk collect into tar from xx where id=ta(i); for i in st loop dbms_output.put(tar(i)); end loop; dbms_output.put_line(' '); end loop; return re; end;
第二章Oracle体系结构
2.表空间的使用
在数据库中使用多个表空间具有如下优势: (1)能够将数据字典与用户数据分离开来,避免 由于字典对象和用户对象保存在同一个数据文件 中而产生的1/0冲突。 (2)能够将回退数据与用户数据分离开来,避免 由于硬盘损坏而导致永久性的数据丢失。 (3)能够将表空间的数据文件分散保存到不同硬 盘上,平均分布物理1/0操作。
(4)LGWR日志文件写进程 该进程是日志缓冲区的管理进程,负责把日志缓冲区中 的日志项写入磁盘上的日志文件中。 (5)ARCH归档进程(archiver process) 该进程把已经填满的在线日志文件拷贝到一个指定的存 储设备上。 (6)RECO恢复进程 该进程是在具有分布式选项时使用的一个进程,主要用 于解决引用分布式事务时所出现的故障。 (7)LCKN封锁进程
2.4.2 进程
进程又称任务,是操作系统中一个极为重要的 概念。一个进程执行一组操作,完成一个特定 的任务。对Oracle数据库管理系统来说,进程由 用户进程、服务器进程和后台进程所组成。 进程与程序的区别在于前者是一个动态概念, 后者是一个静态实体;程序仅仅是指令的有序 集合,而进程则强调执行过程。进程可以动态 地创建,完成任务后即会消亡。
2.2.4 数据库块
数据库块也称逻辑块或Oracle块,它对应 磁盘上一个或多个物理块,它的大小由初 始化参数db_block_size(在文件init.ora中) 决定,典型的大小是2k。
Pckfree和Pctused两个参数用来优化数据 块空间的使用。 PCTFREE : 块 中 保 留 用 于 UPDATE 操作的空间百分比,当数据占用的空间达 到此上限时,新的数据将不能再插入到此 块中; PCTUSED:指定块中数据使用空间 的最低百分比;
oracle数据库面试题目(3篇)
第1篇1. 请简述Oracle数据库的体系结构,并说明各层的作用。
2. 请解释什么是Oracle实例?实例与数据库之间的关系是什么?3. 请简述Oracle数据库的存储结构,包括数据文件、控制文件、日志文件等。
4. 请说明Oracle数据库的内存结构,包括SGA、PGA等。
5. 请解释Oracle数据库的备份策略,包括全备份、增量备份、差异备份等。
6. 请说明Oracle数据库的恢复策略,包括不完全恢复、完全恢复等。
7. 请解释Oracle数据库的事务管理,包括事务的ACID特性。
8. 请说明Oracle数据库的锁机制,包括共享锁、排他锁等。
9. 请解释Oracle数据库的并发控制,包括多版本并发控制(MVCC)。
10. 请说明Oracle数据库的安全机制,包括角色、权限、用户等。
二、SQL语言1. 请简述SQL语言的组成,包括数据定义语言(DDL)、数据操纵语言(DML)、数据控制语言(DCL)等。
2. 请说明如何创建一个简单的表,包括表结构、字段类型、约束等。
3. 请编写一个查询语句,查询某个表中所有年龄大于30岁的记录。
4. 请编写一个更新语句,将某个表中年龄大于40岁的记录的年龄加1。
5. 请编写一个删除语句,删除某个表中年龄小于20岁的记录。
6. 请编写一个插入语句,插入一条记录到某个表中。
7. 请说明如何使用SQL语句实现分页查询。
8. 请说明如何使用SQL语句实现多表查询。
9. 请说明如何使用SQL语句实现子查询。
10. 请说明如何使用SQL语句实现联合查询。
三、Oracle高级特性1. 请解释什么是视图?如何创建视图?2. 请解释什么是索引?有哪些常见的索引类型?3. 请解释什么是触发器?如何创建触发器?4. 请解释什么是存储过程?如何创建存储过程?5. 请解释什么是函数?如何创建函数?6. 请解释什么是包?如何创建包?7. 请解释什么是序列?如何创建序列?8. 请解释什么是同义词?如何创建同义词?9. 请解释什么是物化视图?如何创建物化视图?10. 请解释什么是分区表?如何创建分区表?四、Oracle性能优化1. 请说明如何查看Oracle数据库的性能统计信息。
第4章ORACLE服务器体系结构和组成
PFILE子句是必需的,SPFILE子句可以省略, 那么SPFILE存贮在缺省位置 <ORACLE_HOME>\DATABASE\下。
ORACLE的体系构造 物理构 造
• 查看效劳器端参数文件
• 在SQL PLUS中使用SHOW PARAMETERS命令
• 修改效劳器端参数文件
• 在9i中直接手工修改本地参数化文件是没 用的,不会改变数据库的设置。
• 利用ALTER SYSTEM SET parameter = value语句可以在数据库运行时修改初始化参 数的值。
• 在SET子句中可以使用SCOPE选项来设 置影响范围,所谓影响范围就是ALTER SYSTEM语句对参数的修改是仅对当前实例 有效〔记录在内存中〕,还是永久有效〔记 录在SPFILE中〕。
日志缓冲存储区〔Log Buffer〕 日志缓冲区
以记录项的形式备份数据库缓
冲区中被修改的缓冲块,这些
记录将被写到日志文件中。
LOG_BUFFER
日志文件
确定日志缓冲区的大小。
ORACLE的体系构造 图示
PMON LCKn RECO SMON
共享池
SGA
数据缓冲区 日志缓冲区
体系构造
Server UUUssseeerrr
当一个日志文件组被填满时
关闭数据库时
ORACLE的体系构造 物理构 造
日志文件写操作图示
Log File 2
ORACLE的体系构造 物理构 造
镜像日志文件是为防止日志文件的丧失,在 不同磁盘上同时维护两个或多个联机日志文件 的副本。 其特点如下: 每个日志文件组至少包含两个日志文件成员。 每组的成员数目一样。 同组的所有成员同时被修改。 同组的成员大小一样,不同组的成员大小可 不同。
oracle数据库基本概念
Oracle数据库是一种关系数据库管理系统(RDBMS)。
以下是Oracle数据库的一些基本概念:
1.数据库(Database):物理上表现为数据文件、日志文件和控制文件等,逻辑上以表空
间形式存在。
必须先创建数据库,才能使用Oracle。
2.全局数据库名(Global Database Name):用于区分一个数据库的标识,在安装数据库、
创建数据库、创建控制文件、修改数据库结构、利用RMAN备份时都需要使用。
它由数据库名称和域名构成,使得数据库的命名在整个网络环境中唯一。
3.数据库实例(Database Instance):每个启动的数据库都对应一个数据库实例,由这个
实例来访问数据库中的数据。
4.表空间(Tablespace):一个Oracle数据库能够有一个或多个表空间,而一个表空间则
对应着一个或多个物理的数据库文件,但一个数据库文件只能与一个表空间相联系。
表空间是Oracle数据库恢复的最小单位,容纳着许多数据库实体,如视图、索引、聚簇、回退段和临时段等。
5.关系数据库(Relational Database):按照二维表结构方式组织的数据集合,每个表体
现了集合理论中定义的数学概念——关系。
这些基本概念有助于理解Oracle数据库的结构和运作方式。
oracle控制文件概述
加强交通建设管理,确保工程建设质 量。10:09:2410:09:2410:09Thursday, October 15, 2020
安全在于心细,事故出在麻痹。20.10.1520.10.1510:09:2410:09:24October 15, 2020
严格把控质量关,让生产更加有保障 。2020年10月 上午10时9分20.10.1510:09Oc tober 15, 2020
作业标准记得牢,驾轻就熟除烦恼。2020年10月15日星期 四10时9分24秒 10:09:2415 October 2020
好的事情马上就会到来,一切都是最 好的安 排。上 午10时9分24秒 上午10时9分10:09:2420.10.15
wanghailiang
4
建立控制文件
• 修改数据库名 • 修改永久参数 • 恢复控制文件
wanghailiang
5
建立控制文件示例
wanghailiang
6
显示控制文件信息
V$CONTROLFILE V$CONTROLFILE_RECORD_SECTION
wanghailiang
7
练习三
牢记安全之责,善谋安全之策,力务 安全之 实。2020年10月15日 星期四10时9分 24秒T hursday, October 15, 2020
相信相信得力量。20.10.152020年10月 15日星 期四10时9分24秒20.10.15
谢谢大家!
树立质量法制观念、提高全员质量意 识。20.10.1520.10.15Thursday, October 15, 2020
oracle storage参数
oracle storage参数Oracle存储参数是在Oracle数据库中用来控制存储结构和存储行为的重要设置。
合理配置这些参数可以提高数据库的性能和可用性。
本文将介绍一些常用的Oracle存储参数,包括数据文件、表空间、日志文件和缓冲区等。
一、数据文件参数1. 数据文件大小(DB_BLOCK_SIZE):指定数据库块的大小,一般为4KB或8KB。
较小的块大小适合处理小型事务,而较大的块大小适合处理大型事务。
2. 数据文件自动扩展(AUTOEXTEND):指定数据文件是否可以自动扩展。
当数据文件满了时,自动扩展可以避免数据库停机。
3. 数据文件增长率(NEXT):指定数据文件每次扩展的大小。
合理设置增长率可以避免频繁的扩展操作,提高数据库性能。
二、表空间参数1. 表空间类型(BIGFILE/SMALLFILE):指定表空间是使用大文件还是小文件。
大文件表空间可以提供更大的存储容量,但可能会影响备份和恢复速度。
2. 表空间大小(SIZE):指定表空间的初始大小。
根据数据库的需求和预估的数据增长率,合理设置表空间大小可以避免空间浪费和频繁的扩展操作。
3. 表空间自动扩展(AUTOEXTEND):指定表空间是否可以自动扩展。
当表空间满了时,自动扩展可以避免数据库停机。
三、日志文件参数1. 日志文件大小(LOG_FILE_SIZE):指定日志文件的大小。
较大的日志文件可以减少频繁的切换操作,提高数据库性能。
2. 日志文件组数(LOG_FILE_GROUPS):指定日志文件的组数。
多个日志文件组可以提高并发写入的能力,增加数据库的容错性。
3. 日志文件切换(LOG_SWITCH_WAIT):指定日志文件切换的时间间隔。
合理设置切换间隔可以平衡日志文件的使用和性能。
四、缓冲区参数1. 数据库缓冲区大小(DB_CACHE_SIZE):指定数据库缓冲区的大小。
较大的缓冲区可以提高数据库的响应速度和查询性能。
2. 共享池大小(SHARED_POOL_SIZE):指定共享池的大小。
表空间及模式对象
复用控制文件(1)
alter system set control_files='E:\ORACLE\ORADATA\YIDB\CONT ROL01.CTL','E:\ORACLE\ORADATA\YIDB\CONT ROL02.ctl','E:\ORACLE\ORADATA\YIDB\CONTR OL03.ctl','E:\ORACLE\ORADATA\YIDB\CONTRO L04.ctl' scope=both; 关闭数据库 复制控制文件到新的磁盘位置。 打开数据库
表中所有行的开始ROWID 表中所有行的结束ROWID 位图模式
列值
男 女
AAAvQAAGAAA3yAAA AAAQAAGZZZZ3yZZZ
1011… 0100…
位图模式中,表中的每一行占一位
性别
100
基数: 列中包含许多不同值,则列具有较高基数 包含少数不同值,则列具有较低的基数。 基数高的列适合建B树索引 基数较低的列适合用位图索引。
ALTER TABLESPACE userdata RENAME DATAFILE 'E:\oracle\product\10.2.0\oradata\orcl\userdata02.dbf' TO 'E:\oracle\product\10.2.0\oradata\orcl\userdata03.dbf';
模式对象 :表、列、约束 索引 序列 同义词 视图
索引
索引是数据库中的对象,建立于表之上,独 立于表。 避免全表扫描,用于提高查询速度。 索引包括:B-树索引 、位图索引 、函数索引 、反序索引
oracle10g数据库管理应用与开发课后答案
oracle10g数据库管理应用与开发课后答案Oracle10g数据库管理应用与开发课后习题答案(填空与选择题)填空题第二章1.Oracle数据库系统的物理存储结构主要由3类文件组成,分别为数据文件、日志文件、控制文件。
2.用户对数据库的操作如果产生日志信息、则该日志信息首先被存储在日志缓冲区中,随后由LGWR进程保存到日志文件。
3.一个表空间物理上对应一个或多个数据文件。
4.在Oracle的逻辑存储结构中,根据存储数据的类型,可以将段分为数据段、索引段、回退段、LOB段和临时段。
5.在Oracle的逻辑存储结构中,数据块是最小的I/O单元。
6.在多进程Oracle实例系统中,进程分为用户进程、后台进程和服务器进程。
当一个用户运行应用程序,如PRO某C程序或一个Oracle工具(如SQL某Plu),系统将为用户运行的应用程序建立一个用户进程。
第三章1.标准的SQL语言语句类型可以分为:数据定义语句(DDL)、数据操纵语句(DML)和数据控制语句(DCL)。
2.在需要滤除查询结果中重复的行时,必须使用关键字Ditinct;在需要返回查询结果中的所有行时,可以使用关键字ALL。
3.如果需要在SELECT子句中包括一个表的所有列,可使用符号某。
4.如果定义与组有关的搜索条件,可以把groupby子句添加到SELECT语句中。
5.当进行模糊查询时,就使用关键字LIKE和通配符\或百分号\。
6.WHERE子句可以接收FROM子句输出的数据,而HAVING子句则可以接收来自groupby、FROM或where子句的输入。
GROUPBY供应商所在城市ORDERBY2DESC;第四章1.在SQL语句中,用于向表中插入数据的语句是Inert。
2.如果需要向表中插入一批已经存在的数据,可以在INSERT语句中使用elect语句。
3.创建一个UPDATE语句来修改ARTISTS表中的数据,并且把每一行的T_ID值都改成15,应该使用的SQL语句是updateartitett_id=15;。
1数据库的物理结构有哪几种文件组成
1数据库的物理结构有哪几种文件组成?数据文件重做日志文件控制文件其他文件2简要说明例程与数据库之间的联系与区别、ORACLE数据库是安装在磁盘上的ORACLE数据库文件和相关的数据库管理系统的集合。
磁盘上比较重要的文件包括数据文件,控制文件重做日志文件初始化参数文件口临文件。
鬼档重做日志文件例程是由在内从中的一组后台京城和内存结构组成。
3说明数据库,表空间和数据文件之间的关系。
ORACLE数据库的逻辑结构和物理结构的对应关系,一个ORACLE数据库可以拥有多个表空间,每个表空间有多个段组成,每个段由若干个区间组成,每个区间包含多个ORACLE 数据块,每个ORACLE数据块包含多个OS屋里磁盘快。
表空间有多个物理文件支持,具体存储表空间中的个对象。
4说明ORACLE 例程的系统全局区包括哪几部分?风别存储什么?主要包括数据库缓冲存储区,崇左日志缓冲区共享池三部分。
1用于存放最近访问的数据块。
2数据进行的所有更改都存储在崇左日志缓冲区,这些记录在以后会备考摆到重做日志文件中。
3共享池用于存放最近执行的SQL语句和数据字典信息,它的尺寸是由初始化参数SHARED_PLLL_SIZE来定义的。
大池用于为大的内存需求提供内存空间,它的尺寸有初始化参数LARGE_POOL SIZE定义。
6有几种日志操作模式?扎那几种日志操作模式下会生成归档日志?7ORACLE罗技存储结构有哪几部分构成?由表空间,段,区间,ORACLE块构成。
8 ORACLE数据库系统中的进程主要由用户进程和服务器端进程,服务器端进程又可以分为后台进程和服务器进程两类。
服务器端后台进程:数据库写入进程,日志写入进程,日志归档进程(不必要),检查带你进程,系统监控进程和进程监控进程三章ORACLE NET 是ORACLE网络产品的基础,他用需服务和他们的应用程序驻留在不同的计算机上,其主要功能是在客户机和服务器之间活在两个服务器之间建立网络绘画和传输数据。
oracle storage参数
oracle storage参数Oracle Storage参数是指在Oracle数据库中,用于控制数据存储和访问的一组参数。
这些参数可以影响数据库的性能、可靠性和安全性。
在Oracle数据库中,存储参数主要包括表空间、数据文件、日志文件和控制文件等。
表空间是Oracle数据库中存储数据的基本单位。
每个表空间都有一个或多个数据文件,用于存储表、索引和其他对象。
表空间的大小、块大小、自动扩展和压缩等参数可以通过ALTER TABLESPACE语句进行修改。
在创建表空间时,可以指定不同的存储参数,如块大小、初始大小、最大大小等。
数据文件是存储表空间中数据的物理文件。
每个数据文件都有一个唯一的文件名和路径。
数据文件的大小、自动扩展和压缩等参数可以通过ALTER DATABASE DATAFILE语句进行修改。
在创建数据文件时,可以指定不同的存储参数,如块大小、初始大小、最大大小等。
日志文件是Oracle数据库中记录事务操作的文件。
每个日志文件都有一个唯一的文件名和路径。
日志文件的大小、数量、自动切换和归档等参数可以通过ALTER SYSTEM SWITCH LOGFILE语句进行修改。
在创建日志文件时,可以指定不同的存储参数,如大小、数量、自动切换等。
控制文件是Oracle数据库中记录数据库结构和状态的文件。
每个控制文件都有一个唯一的文件名和路径。
控制文件的大小、数量、自动备份和恢复等参数可以通过ALTER DATABASE CONTROLFILE语句进行修改。
在创建控制文件时,可以指定不同的存储参数,如大小、数量、自动备份等。
除了以上存储参数外,Oracle数据库还有其他一些存储相关的参数,如SGA(System Global Area)、PGA(Program Global Area)、TEMP表空间等。
这些参数可以通过ALTER SYSTEM语句进行修改。
总之,Oracle Storage参数是Oracle数据库中非常重要的一组参数,它们可以影响数据库的性能、可靠性和安全性。
Oracle 数据库简答题
第一章简答题1.简述Oracle数据库逻辑结构中各元素之间的关系。
答:数据库由若干个表空间组成,表空间由表、索引、视图等逻辑对象组成,表由段组成,段由区组成,区则由数据块组成。
2.简述Oracle数据库物理结构中包含的文件类型,以及不同类型文件所能起的作用。
答:物理结构由构成数据库的操作系统文件所决定。
每个Oracle数据库都由3种类型的文件组成:数据文件、日志文件和控制文件。
Oracle数据库有一个或多个物理的数据文件。
数据库的数据文件包含全部数据库数据。
逻辑数据物理地存储在数据文件中。
每个数据库有两个或多个日志文件组,日志文件组用于收集数据库日志。
日志的主要功能是记录对数据所作的修改,所以对数据库作的全部修改记录在日志中。
在出现故障时,如果不能将修改数据永久地写入数据文件,则可利用日志得到修改记录,从而保证已经发生的操作成果不会丢失。
每个Oracle数据库有一个控制文件,记录数据库的物理结构。
控制文件包含数据库名、数据库数据文件和日志文件的名字、位置和数据库建立日期等信息。
3.简述SGA所包含的数据结构及其描述信息。
答:SGA是一组共享内存结构,其中包含一个Oracle数据库例程数据及控制信息。
如果有多个用户同时连接到同一个例程,则此例程的SGA数据由这些用户共享。
因此,SGA也称为共享全局区(Shared Global Area)。
SGA包含以下数据结构。
∙数据库缓冲区:SGA用来保存从数据文件中读取的数据块。
∙重做日志缓冲区:SGA中的循环缓冲区,用于记录数据库发生改变的信息。
∙共享池:用于保存用户程序。
∙Java池:为Java命令提供语法分析。
∙大型池:数据库管理员配置的可选内存区域,用于分配大量的内存。
4.简述Oracle数据库管理员的主要职责。
答:数据库管理员的主要职责如下。
∙安装和升级Oracle数据库服务器和其他应用工具。
∙分配系统存储空间,并计划数据库系统未来需要的存储空间。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验四oracle 数据库管理一、试验目的掌握对数据文件、表空间、日志文件、控制文件的常用命令,作为DBA的必要准备。
二、实验容2.1 数据文件的管理(1)在安装完毕之后,在INITsid.ORA参数文件有一个DB_FILES 参数,用于设置当前实例的数据外文件的个数。
如:db_files = 80如果在INITsid.ORA文件没有该参数,则可以用下面查询语句从视图中查到。
如:SQL> col name for a20SQL> col value for a50SQL> set lin 100SQL> select name,value from v$parameter where name = 'db_files';NAME VALUE-------------------- --------------------------------------------------db_files 1024(2)行命令建立表空间:例1 CREATE TABLESPACE user_stuDATAFILE 'h:/oracle/oradata/orcl/user_stu.dat' SIZE 20MDEFAULT STORAGE( INITIAL 10KNEXT 50KMINEXTENTS 1MAXEXTENTS 99PCTINCREASE 10 )ONLINE ;例2:建立一个新的表空间,具有两个数据文件:CREATE TABLESPACE CRM_TABDATAFILE 'h:/oracle/oradata/orcl/crm01.dbf' size 10 MB,'h:/oracle/oradata/orcl/crm02.dbf' size 10 MB;(3)对一个已存在的表空间追加新数据文件:例1 ALTER TABLESPACE user_stuAdd datafile 'H:/oracle/oradata/orcl/user_stu01.dbf' size 30M;例2 为表空间增加数据文件ALTER TABLESPACE usersADD DATAFILE 'userora1.dbf ' SIZE 10M ;(4)数据文件更名ALTER TABLESPACE usersRENAME DATAFILE? 'filename1', 'filename2'TO 'filename3', 'filename4' ;(5)变更数据文件大小在创建表空间时,可以将表空间说明为自动扩展或固定大小。
因而管理员的一项工作就是查看系统所有的表空间对应的数据文件情况。
看是否为自动扩展。
如:SQL> col tablespace_name for a12SQL> col file_name for a48SQL> select tablespace_name,file_name,AUTOEXTENSIBLE ,bytes from dba_data_files(6)数据文件的自动扩展与调整。
重新调整数据文件大小的命令如下:ALTER DATABASE DATAFILE [datafile_name] RESIZE [new_size];当我们发现数据文件过大而不可能用完时,可以用上面命令将数据文件调小。
对于设置数据文件的自动扩展问题,可用下面命令来达到:ALTER DATABASE DATAFILE [ file_spec ]AUTOEXTEND ON NEXT [increment_size] MAXSIZE [max_size,UNLIMITED];如:ALTER DATABASE DATAFILE 'H:\ORACLE\ORADATA\ORCL\USER_STU01.DBF' AUTOEXTEND ON NEXT 10m MAXSIZE 60M;(7)行命令修改表空间:ALTER TABLESPACE USER_STUONLINE ;(8)ALTER TABLESPACE accountingOFFLINE NORMAL;(9)行命令删除表空间:DROP TABLESPACE 表空间名INCLUDING CONTENTSCASCADE CONSTRAINTS(10)、与数据文件有关的视图select file_name from dba_data_files;select * from v$datafile;DBA_DATA_FILESDBA_EXTENTSDBA_FREE_SPACEV$DATAFILEV$DATAFILE_HEADER(11)、为了保证表空间的可用,除了掌握表空间的创建外,还应该查看dba_free_space中表空间的信息,以确保系统正常运行。
一般管理员应该关心的容有:表空间共有多少个;总共有多少自由空间;最大的自由空间是什么;下面例子是一个经常使用的脚本,可以查出数据文件和表空间的可用情况。
clear bufferclear columnsclear breakscolumn a1 heading 'Tablespace' format a15column a2 heading 'data File' format a45column a3 heading 'Total|Space' format 999,999.99column a4 heading 'Free|Space' format 999,999.99column a5 heading 'Free|perc' format 999,999.99break on a1 on reportcompute sum of a3 on a1compute sum of a4 on a1compute sum of a3 on reportcompute sum of a4 on reportset linesize 120select a.tablespace_name a1, a.file_name a2, a.avail a3, nvl(b.free,0) a4,nvl(round(((free/avail)*100),2),0) a5from (select tablespace_name, substr(file_name,1,45) file_name,file_id, round(sum(bytes/(1024*1024)),3) availfrom sys.dba_data_filesgroup by tablespace_name, substr(file_name,1,45),file_id) a,(select tablespace_name, file_id,round(sum(bytes/(1024*1024)),3) freefrom sys.dba_free_spacegroup by tablespace_name, file_id) bwhere a.file_id = b.file_id (+)order by 1, 2;(12) 查询是否存在表的扩展超出表空间可用大小一般在系统使用较长时间后,表空间的连续块被多次的修改与删除等操作后出现了多的不连续的块(叫碎片)。
这样就有可能出现表的扩展所需要的连续块不能满足的情况。
为了避免这样的情况发生而导致扩展失败,管理员要经常查询系统的表空间情况。
下面就是这样的一个脚本:Col segment_name for a20Select segment_name, segment_type, owner, a.tablespace_name tablespace,Initial_extent, next_extent, pct_increase,b.bytes max_bytesFrom dba_segments a,( select tablespace_name, max(bytes) bytes from dba_free_spacegroup by tablespace_name ) bwhere a.tablespace_name=b.tablespace_name and next_extent > b.bytes ;(13) 查询表空间自由、最大及碎片其实,平常管理最关系就是表空间的总量、最大字节、使用多少、碎片多少等。
下面脚本可以查询出所有表空间的自由空间、总空间数、已用空间、自由百分比及最大块的字节数。
set pau offcol free heading 'Free(Mb)' format 99999.9col total heading 'Total(Mb)' format 999999.9col used heading 'Used(Mb)' format 99999.9col pct_free heading 'Pct|Free' format 99999.9col largest heading 'Largest(Mb)' format 99999.9compute sum of total on reportcompute sum of free on reportcompute sum of used on reportbreak on reportselect substr(a.tablespace_name,1,13) tablespace,round(sum(a.total1)/1024/1024, 1) Total,round(sum(a.total1)/1024/1024, 1)-round(sum(a.sum1)/1024/1024, 1) used,round(sum(a.sum1)/1024/1024, 1) free,round(sum(a.sum1)/1024/1024, 1)*100/round(sum(a.total1)/1024/1024, 1) pct_free,round(sum(a.maxb)/1024/1024, 1) largest,max(t) fragmentfrom(select tablespace_name, 0 total1, sum(bytes) sum1,max(bytes) MAXB,count(bytes)tfrom dba_free_spacegroup by tablespace_nameunionselect tablespace_name, sum(bytes) total1, 0, 0, 0 from dba_data_filesgroup by tablespace_name) agroup by a.tablespace_name2.2 日志文件的管理(0)日志查询select group#,bytes from v$log;?select group#,bytes from v$logfile;(1)实现强行的日志切换Alter system switch logfile;(2)检测点(checkpoint)Oracle为了在出现故障后能退回去重演原来的信息,就需要一个叫开始点。