Oracle
基于客户端/服务器技术,处理多个客户端对同一数据的并发访问
Oracle服务器
由Oracle数据库和Oracle实例组成
Oracle实例
管理数据库的后台进程和内存结构的集合称为 Oracle 实例
实例启动时分配SGA并启动后台进程,一个实例只能打开一个数据库 内存结构包含系统全局区(SGA)和程序全局区(PGA)
系统全局区(SGA)
数据库信息存储于SGA,由多个数据库进程共享 包含共享池 ,数据缓冲区 ,日志缓冲区
共享池
共享池是对SQL、PL/SQL程序进行语法分析、编译、执行的内存区域 共享池由库缓存和数据字典缓存组成。 共享池的大小直接影响数据库的性能
数据缓冲区
用于存储从磁盘数据文件中读入的数据,所有用户共享。
服务器进程将读入的数据保存在数据缓冲区中,当后续的请求需要这些数据时可以在内存中找到,不需要再从磁盘读取,
提高了读取速度。 数据缓冲区的大小对数据库的读取速度有直接的影响。
日志缓冲区
日志记录数据库的所有修改信息,日志信息首先产生于日志缓冲区。
当日志缓冲区的日志数据达到一定数量时,由后台进程将日志数据写入日志文件中。 相对来说,日志缓冲区对数据库的性能影响较小
程序全局区(PGA)--用户私有
程序全局区(PGA)包含单个服务器进程所需的数据和控制信息
PGA是在用户进程连接到数据库并创建一个会话时自动分配该内存区,保存每个与Oracle 数据库连接的用户进程所需的
信息 PGA为非共享区,只能单个进程使用,当一个用户会话结束,PGA释放
实例进程--用户进程 服务器进程 后台进程
用户进程用户请求连接服务器时启动 服务器进程当用户建立会话时启动
后台进程是Oracle数据库为了保持最佳系统性能和协调多个用户请求而设置的。程
Oracle数据库
包括逻辑结构和物理结构
逻辑结构指数据库创建之后形成的逻辑概念之间的关系
Oracle 实例启动时即创建一系列后台进
会话
用户与 Oracle 服务器的单个连接
Oracle 物理组件
数据文件 控制文件 日志文件
Oracle 逻辑组件
数据库----表空间----段----区----数据块
表空间
是数据库中最大的逻辑单位,一个 Oracle 数据库至少包含一个表空间, 就是名为SYSTEM的系统表空间
每个表空间是由一个或多个数据文件组成的,一个数据文件只能与一个表空间相关联 表空间的大小等于构成该表空间的所有数据文件大小之和
CREATE TABLESPACE tablespacename
DATAFILE ‘filename’ [SIZE integer [K|M]] [AUTOEXTEND [OFF|ON]];
段
段是构成表空间的逻辑存储结构,段由一组区组成。
按照段所存储数据的特征,将段分为四种类型,即数据段、索引段、回退段和临时段。
区
区为段分配空间,它由连续的数据块组成。
当段中的所有空间已完全使用时,系统自动为该段分配一个新区。 区不能跨数据文件存在,只能存在于一个数据文件中
数据块
数据块是Oracle服务器所能分配、读取或写入的最小存储单元。 Oracle服务器以数据块为单位管理数据文件的存储空间
Oracle服务器与Oracle实例



