Oracle10g数据库基础教程2012第6章物理存储结构Oracle10g数据库基础教程2012本章内容Oracle数据库系统结构数据文件控制文件重做日志文件归档重做日志文件Oracle10g数据库基础教程2012本章要求理解Oracle数据库的系统结构掌握数据文件的管理掌握控制文件的作用及其管理掌握重做日志文件的工作方式及其管理掌握数据库归档模式设置及归档管理Oracle10g数据库基础教程20126.1Oracle数据库系统结构Oracle数据库系统结构由数据库实例和物理存储结构组成。(内存结构)Oracle10g数据库基础教程2012在Oracle数据库的存储结构包括物理存储结构和逻辑存储结构。物理存储结构:主要用于描述Oracle数据库外部数据的存储,即在操作系统中如何组织和管理数据,与具体的操作系统有关;逻辑存储结构:主要描述Oracle数据库内部数据的组织和管理方式,与操作系统没有关系。物理存储结构是逻辑存储结构在物理上的、可见的、可操作的、具体的体现形式。Oracle10g数据库基础教程2012表空间段区块OS块数据文件逻辑结构数据库控制文件重做日志文件物理结构1n逻辑角度物理角度Oracle10g数据库基础教程2012Oracle数据库物理存储结构指存储在磁盘上的物理文件:Oracle10g数据库基础教程2012功能:数据文件:用于存储数据库中的所有数据;控制文件:用于记录和描述数据库的物理存储结构信息;重做日志文件:用于记录外部程序(用户)对数据库的改变操作;归档文件:用于保存已经写满的重做日志文件;初始化参数文件:用于设置数据库启动时的参数初始值;跟踪文件:用于记录用户进程、数据库后台进程等的运行情况;口令文件:用于保存具有SYSDBA,SYSOPER权限的用户名和SYS用户口令;警告文件:用于记录数据库的重要活动以及发生的错误;备份文件:用于存放数据库备份所产生的文件。Oracle10g数据库基础教程20126.2数据文件及其管理数据文件概述数据文件的管理Oracle10g数据库基础教程20126.2.1数据文件概述数据文件的内容用于保存数据库中所有数据的文件,扩展名为DBF。临时数据文件是一种特殊的数据文件,其存储内容是临时性的,在一定条件下自动释放。Oralce数据库中的每个数据文件都具有两个文件号,用于唯一地确定一个数据文件。绝对文件号:用于在整个数据库范围内唯一标识一个数据文件;相对文件号:用于在表空间范围内唯一标识一个数据文件。数据文件与表空间的关系数据文件依附于表空间存在表空间数据文件1nOracle10g数据库基础教程2012数据文件的管理策略数据文件的最大数量:使用初始化参数DB_FILES限制数据文件的大小数据文件的存储位置:把不同存储内容的数据文件放置在不同的硬盘上,可以并行访问数据,提高系统读写的效率。初始化参数文件、控制文件、重做日志文件最好不要与数据文件存放在同一个磁盘上,以免数据库发生介质故障时,无法恢复数据库。受OS的限制Oracle10g数据库基础教程20126.2.2数据文件的管理创建数据文件修改数据文件的大小改变数据文件的可用性改变数据文件的名称或位置删除数据文件查询数据文件的信息利用OEM管理数据文件Oracle10g数据库基础教程2012(1)创建数据文件数据文件依附于表空间而存在,创建数据文件就是向表空间添加文件。在创建数据文件时,应该根据文件数据量的大小确定文件的大小以及文件的增长方式。命令语法:CREATETABLESPACE/DATABASECREATETEMPORARYTABLESPACEALTERDATABASE…CREATEDATAFILE(数据库恢复时)ALTERTABLESPACE…ADDDATAFILEALTERTABLESPACE…ADDTEMPFILE数据库运行与维护时采用注意:进行这些操作必须具备管理员权限!Oracle10g数据库基础教程2012例1:向ORCL数据库的USERS表空间中添加一个大小为10MB的数据文件。例2:向ORCL数据库的TEMP表空间中添加一个大小为5MB的临时数据文件。SQLALTERTABLESPACEUSERSADDDATAFILE2'D:\oracle\product\10.2.0\oradata\ORCL\3USERS02.DBF'SIZE10M;SQLALTERTABLESPACETEMPADDTEMPFILE2'D:\oracle\product\10.2.0\oradata\ORCL\3TEMP02.DBF'SIZE5M;注意:若指定的数据文件已经存在(指DB系统中已经存在同名的文件,但是无效的DB文件或非DB文件),可以使用REUSE子句进行覆盖。如果,该同名文件是DB的有效文件,则不能覆盖!Oracle10g数据库基础教程2012(2)修改数据文件大小两种方法设置数据文件为自动增长方式优点:⑴DBA无须过多干涉数据库存储空间的分配问题⑵可以保证应用程序不会因为分配空间不足而导致错误手工改变数据文件的大小设置数据文件为自动增长方式创建时设置:CREATEDATABASE/TABLESPACE…ALTERTABLESPACE…ADDDATAFILE…创建后修改:ALTERDATABASEDATAFILE…AUTOEXTENDONNEXT…MAXSIZE…|UNLIMITEDAUTOEXTENDON指定数据文件每次自动增长的大小指定数据文件的极限大小指定数据文件大小没有限制Oracle10g数据库基础教程2012手工改变数据文件的大小ALTERDATABASEDATAFILE…RESIZE…例3:为ORCL数据库的USERS表空间添加一个自动增长的数据文件USERS03.DBF。例4:修改ORCL数据库USERS表空间的数据文件USERS02.DBF为自动增长方式。SQLALTERTABLESPACEUSERSADDDATAFILE2'D:\oracle\product\10.2.0\oradata\ORCL\USERS03.DBF'3SIZE10MAUTOEXTENDONNEXT512KMAXSIZE50M;SQLALTERDATABASEDATAFILE2'D:\oracle\product\10.2.0\oradata\ORCL\USERS02.DBF'3AUTOEXTENDONNEXT512KMAXSIZEUNLIMITED;Oracle10g数据库基础教程2012例5:取消ORCL数据库USERS表空间的数据文件USERS02.DBF的自动增长方式。例6:将ORCL数据库USERS表空间的数据文件USERS02.DBF大小设置为8MB。SQLALTERDATABASEDATAFILE2'D:\oracle\product\10.2.0\oradata\ORCL\USERS02.DBF'3AUTOEXTENDOFF;SQLALTERDATABASEDATAFILE2'D:\oracle\product\10.2.0\oradata\ORCL\USERS02.DBF'3RESIZE8M;Oracle10g数据库基础教程2012(3)改变数据文件的可用性概念可以通过将数据文件联机或脱机来改变数据文件的可用性。下面几种情况:进行数据文件的脱机备份时;重命名数据文件或改变数据文件的位置时;写入某个数据文件时发生错误,会自动将该数据文件设置为脱机状态,并且记录在警告文件中。排除故障后,需要以手动方式重新将该数据文件恢复为联机状态。数据文件丢失或损坏,需要在启动数据库之前将数据文件脱机。Oracle10g数据库基础教程2012归档模式下数据文件可用性的改变数据文件可用性的改变ALTERDATABASEDATAFILE…ONLINE|OFFLINE临时数据文件可用性的概念改变ALTERDATABASETEMPFILE…ONLINE|OFFLINE说明:数据库的运行可以根据是否进行重做日志文件归档,而分为归档模式和非归档模式。详见6.5Oracle10g数据库基础教程2012例7:在数据库处于归档模式下,将ORCL数据库USERS表空间的数据文件USERS02.DBF脱机。例8:将ORCL数据库USERS表空间的数据文件USERS02.DBF联机。SQLALTERDATABASEDATAFILE2'D:\oracle\product\10.2.0\oradata\ORCL\USERS02.DBF'3OFFLINE;SQLRECOVERDATAFILE2'D:\oracle\product\10.2.0\oradata\ORCL\USERS02.DBF';SQLALTERDATABASEDATAFILE2'D:\oracle\product\10.2.0\oradata\ORCL\USERS02.DBF'3ONLINE;注意:在归档模式下,将数据文件联机前,需要进行恢复操作。使用RECOVERDATAFILE。Oracle10g数据库基础教程2012非归档模式下数据文件可用性的改变在非归档模式下,通常不能将数据文件脱机。如果由于数据文件的损坏,需要将数据文件脱机,然后重新启动数据库,需要使用:ALTERDATABASEDATAFILE…OFFLINEFORDROPSQLALTERDATABASEDATAFILE2'D:\oracle\product\10.2.0\oradata\ORCL\USERS02.DBF'3OFFLINEFORDROP;注意:此时要联机只有采用介质恢复的形式才能够将数据文件设置为联机。Oracle10g数据库基础教程2012改变表空间中所有数据文件的可用性在归档模式下,将表空间所有文件脱机或联机ALTERTABLESPACE...DATAFILEONLINE|OFFLINE在归档模式下,将临时表空间所有临时文件联机或脱机ALTERTABLESPACE...TEMPFILEONLINE|OFFLINE例9:在归档模式下,将USERS表空间中所有的数据文件脱机,但USERS表空间不脱机。然后再将USERS表空间中的所有数据文件联机。SQLALTERTABLESPACEUSERSDATAFILEOFFLINE;SQLRECOVERTABLESPACEUSERS;SQLALTERTABLESPACEUSERSDATAFILEONLINE;Oracle10g数据库基础教程2012(4)改变数据文件的名称或位置通过重命名或移动数据文件,可以在不改变逻辑结构的情况下,对物理结构进行调整。两种情况:改变同一个表空间中的数据文件的名称或位置ALTERTABLESPACLE…RENAMEDATAFILE…TO改变多个表空间中的数据文件的名称或位置ALTERDATABASERENAMEFILE…TO注意:改变数据文件的名称或位置时,Oracle只是改变记录在控制文件和数据字典中的数据文件信息,并没有改变操作系统中数据文件的名称和位置,因此需要DBA手动更改操作系统中数据文件的名称和位置。Oracle10g数据库基础教程2012改变同一个表空间中的数据文件的名称或位置例10:更改ORCL数据库USERS表空间的USERS02.DBF和USERS03.DBF文件名为USERS002.DBF和USERS003.DBF。将包含数据文件的表空间置为脱机状态。在操作系统中重命名数据文件或移动数据文件到新的位置。使用ALTERTABLESPACE…RENAMEDATAFILE…TO语句进行操作。将表空间联机。SQLALTERTABLESPACEUSERSOFFLINE;SQLALTERTABLESPACEUSERSRENAMEDATAFILE'D:\ORACLE\PRODUCT\10