2.1 Oracle体系结构概述
Oracle体系结构主要用来分析数据库的组成、工作过程与原理,以及数据在数据库中的组织与管理机制。这里,Oracle数据库是一个逻辑概念,而不是指安装了Oracle数据库管理系统的服务器。
在Oracle数据库管理系统中有3个重要的概念需要理解,那就是实例(Instance)、数据库(Database)和数据库服务器(Database Server)。其中,实例是指一组Oracle后台进程以及在服务器中分配的共享内存区域;数据库是由基于磁盘的数据文件、控制文件、日志文件、参数文件和归档日志文件等组成的物理文件集合;数据库服务器是指管理数据库的各种软件工具(如SQL*Plus、OEM等)、实例及数据库。从实例与数据库之间的辩证关系来讲,实例用于管理和控制数据库,而数据库为实例提供数据。一个数据库可以被多个实例装载和打开,而一个实例在其生存期内只能装载和打开一个数据库。
数据库的主要功能就是存储数据,数据库存储数据的方式通常称为存储结构,Oracle数据库的存储结构分为逻辑存储结构和物理存储结构。逻辑存储结构用于描述Oracle内部组织和管理数据的方式,而物理存储结构用于展示Oracle在操作系统中的物理文件组成情况。
启动Oracle数据库服务器实际上是在服务器的内存中创建一个Oracle实例,然后用这个实例来访问和控制磁盘中的数据文件。当用户连接到数据库时,实际上首先连接的是数据库的实例,然后由实例负责与数据库进行通信,最后将处理结果返回给用户。图2.1展示了Oracle数据库的基本体系结构,从该图中可以看出,SQL命令从客户端发出后,首先由Oracle的服务器进程进行响应,然后在内存区域中进行语法分析、编译和执行,接着将修改后的数据写入数据文件,将数据库的修改信息写入日志文件,最后将SQL的执行结果返回给客户端。
图2.1 Oracle体系结构