Oracle存储结构包括:物理存储结构和逻辑存储结构。
1.物理结构是由数据文件(data file)、联机日志文件(online redo log file)、控制文件(control file)组成的,当然他也包括一些其他的文件如归档日志文件、参数文件、警报文件、跟踪文件、备份文件等。
2.逻辑结构是由数据块(data block)、区(extents)、段(segment)、表空间(tablespace)组成的.
物理存储结构:
① 数据文件(data file):一个数据库可以由多个数据文件组成的,数据文件是真正存放数据库数据的.一个数据文件就是一个操作系统文件.数据库的对象(表和索引)物理上是被存放在数据文件中的.
数据文件的特征是: A:一个数据文件只能属于一个数据库. B:数据文件可以被设置成自动增长. C:一个或多个数据文件组成了表空间. D:一个数据文件只能属于一个表空间. 当我们要查询一个表的数据的时候,如果该表的数据没有在内存中,那么oracle就要读取该表所在的数据文件,然后把数据存放的内存中.
② 控制文件(control file):一个数据库至少要有一个控制文件,控制文件中存放的数据库的"物理结构信息",正是因为他存放的是数据库的物理结构信息,所以他就显得尤其的重要.这些物理结构信息就包括: A: 数据库的名字. B:数据文件和联机日志文件的名字及位置. C:创建数据库时的时间戳. 为了更好的保护数据库,我们可以镜像控制文件.每个控制文件中的内容就是相同的.镜像了控制文件,即使其中的一个控制文件出现了问题,也不会影响到数据库的损坏,数据的丢失. 在启动数据库的时候,oracle就会根据控制文件中的数据文件和联机日志文件的信息来打开数据库.
③ 联机日志文件(online redo log file): 一个数据库可以有多个联机日志文件,联机日志文件包含了重做记录(undo records).联机日志文件记录了数据库的改变,例如当一次意外导致对数据的改变没有及时的写到数据文件中,那么oracle就会根据联机日志文件中的信息获得这些改变,然后把这些改变写到数据文件中.这也是联机日志文件存在的意义.联机日志文件中重做记录的唯一功能就是用来做实例的恢复.比如,一次系统的意外掉电,导致内存中的数据没有被写到数据文件中.那么oralce就会根据联机日志文件中的重做记录功能包数据库恢复到失败前的状态.
④ 归档日志文件(Archive log file):是联机日志文件的副本,他记录了对数据库改变的历史.
⑤ 参数文件(parameter file):通常情况下指的就是初始化参数文件(initialization parameter file).参数文件包括了初始化参数文件和服务器端参数文件(server parameter file).在数据库启动的时候就会读取参数文件,然后根据参数文件中的参数来分配SGA并启动一系列的后台进程.参数文件中存放的是数据库和实例的参数.
⑥ 警报文件(alert log file):就是警报日志文件,他记录了数据库的重大活动和所发生的错误.警报文件按照时间的先后来记录所发生的重大活动和错误.警报文件的名字的格式是alertSID.log.警报文件的位置是由初始化参数background_dump_desc指定的.
⑦ 跟踪文件(trace log file): 就是跟踪日志文件,每个服务器进程和后台进程都写跟踪文件.例如当后台进程发生了错误的时候,oracle就会把错误的信息写到跟踪文件中.DBA就可以根据跟踪文件的信息来查看进程中所发生的错误.跟踪文件被写到了两个目录中.和服务器进程有关的信息被写到了由初始化参数user_dump_desc指定的目录中,和后台进程有关信息被写到了由初始化参数background_dump_desc指定的目录中.伴随着时间跟踪文件就会被写满,DBA可以手动来删除跟踪文件,也可以限制跟踪文件的大小.初始化参数MAX_DUMP_FILE_SIZE就可以限制跟踪文件的大小.
⑧ 备份文件(backup file): 就是在数据库发生介质损坏的时候用来还原(restore)数据库的,恢复(recover)数据的.