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:指定块中数据使用空间 的最低百分比;
- 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为了在出现故障后能退回去重演原来的信息,就需要一个叫开始点。