《Oracle数据库管理与维护实战》——2.1 Oracle总体结构

简介:

本节书摘来自异步社区出版社《Oracle数据库管理与维护实战》一书中的第2章,第2.1节,作者: 何伟娜 , 常建功,更多章节内容可以访问云栖社区“异步社区”公众号查看。

2.1 Oracle总体结构

Oracle数据库管理与维护实战
总体来说,Oracle服务器由实例(Instance)和数据库(Database)两大部分组成,如图2-1 所示。实例由内存和一组进程组成。数据库则由一系列物理文件组成,这些物理文件是数据库的 载体(注意和通常意义上的数据库区分)。用户通过实例访问数据库。一般情况下,一个实例对应一个数据库,也有例外的情况,例如在实时应用集群的并行系统中,一个数据库则对应多个实例。

image

2.1.1 Oracle实例

实例又叫数据库服务器,由SGA(System Global Area,系统全局区)和一组后台进程组成,SGA和这组后台进程被所有用户共享。数据库实例在数据库启动时建立,建立时给数据库分配共享内存区SGA和一系列后台进程。

SGA用于存放最近常从数据库中查询的数据和一些数据库控制信息。SGA主要包括共享池、数据缓冲区和日志缓冲区,如图2-2所示。

image

根据操作系统中的定义,进程是指在系统中能独立运行并作为资源分配的基本单位。Oracle中的后台进程可以看作是操作者、操作内存和磁盘I/O等资源。后台进程同样也是操作系统进程。

Oracle后台进程由一组进程组成。这组进程主要来操作数据库,管理并控制数据库的状态。后台进程包括PMON(进程监控程序)、SMON(系统监控程序)、DBWR(数据库写入程序)、LGWR(日志写进程)、CKPT(检查点进程)、RECO(数据恢复进程)、ARCH(归档进程)等,除ARCH外,前6个进程都是必须使用的进程。

实例是Oracle服务器的核心,数据库的存取和控制都由它来完成。

2.1.2 数据库

数据库即存在磁盘上的物理文件,有数据文件、控制文件和日志文件三类,数据库安装完后通过文件系统可访问到这些物理文件。这些物理文件是数据库的载体,数据库中的所有数据,包括系统数据都存储在这些物理文件中。后面的章节将会详细讲解如何使用、保护这些物理文件。

2.1.3 Oracle相关的几个概念
Oracle的相关资料中,经常会看到事务、DML、DDL等几个概念。这几个概念不易理解,本书虽然尽量避免使用这几个概念,但还是会使用一些。为方便读者阅读,本节给出这几个概念的定义。

1.事务
事务是从英文Transaction翻译过来的,事务的Oracle官方解释是:事务是包含一个或多个SQL语句的逻辑工作单元。事务中的SQL语句要么全部提交(Commit),要么全部回滚(Rollback)。

从上面的解释看,事务有点类似于操作系统中的进程,执行时不可分割,要么一起提交,要么一起回滚,我们可以将事务理解为与Oracle服务器的一次交互。Oracle中有多种事务类型,包括读写事务、只读事务、离散事务,默认的就是读写事务。

读写事务:指事务可包含查询、插入、更新与删除表记录的SQL语句,即包含更新数据的语句和查询数据的语句。

只读事务:顾名思义,事务中不能包含更新数据的语句,只能对数据进行读操作,不能进行写操作。

离散事务:离散事务主要用来改进数据库性能,在离散事务中将一些耗时的操作集中起来一起执行。

我们可以用“SET TRANSACTION <事务类型>”命令设置事务类型。

2.DML语句
数据库中将SQL语句分成三类:DML语句、DDL语句、DCL语句。DML语句称为数据库维护语言(Data Manipulation Language或者Data Modification Language)。

它包括SELECT、INSERT、UPDATE、DELETE语句,后三个语句会更新表数据,用于实现对表数据的操作。

3.DDL语句
数据定义语言(Data Definition Language,DDL),指一些创建、修改、删除数据库对象的语言,相应的语句有CREATE、ALTER和DROP。

4.DCL语句
数据库控制语言(Data Control Language,DCL),用于控制用户对数据库的访问。常见的三条命令是GRANT、REVOKE、SET ROLE。

我们将常见的SQL命令归纳一下,如表2-1所示。
image

2.1.4 Oracle的结构划分

为更好地理解和管理Oracle,从不同的角度,Oracle服务器结构被分为内部存储结构、进程结构、物理结构以及逻辑结构,本书将从这四部分来介绍数据库管理,下面详细介绍各结构。

相关文章
|
2月前
|
数据采集 Oracle 关系型数据库
实时计算 Flink版产品使用问题之怎么实现从Oracle数据库读取多个表并将数据写入到Iceberg表
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
19天前
|
Oracle 关系型数据库 数据库
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
打开oracle数据库报错“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。 数据库没有备份,无法通过备份去恢复数据库。用户方联系北亚企安数据恢复中心并提供Oracle_Home目录中的所有文件,急需恢复zxfg用户下的数据。 出现“system01.dbf需要更多的恢复来保持一致性”这个报错的原因可能是控制文件损坏、数据文件损坏,数据文件与控制文件的SCN不一致等。数据库恢复工程师对数据库文件进一步检测、分析后,发现sysaux01.dbf文件损坏,有坏块。 修复并启动数据库后仍然有许多查询报错,export和data pump工具使用报错。从数据库层面无法修复数据库。
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
|
7天前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—异常断电导致Oracle数据库数据丢失的数据恢复案例
Oracle数据库故障: 机房异常断电后,Oracle数据库启库报错:“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。数据库没有备份,归档日志不连续。用户方提供了Oracle数据库的在线文件,需要恢复zxfg用户的数据。 Oracle数据库恢复方案: 检测数据库故障;尝试挂起并修复数据库;解析数据文件。
|
6天前
|
Oracle NoSQL 关系型数据库
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
18 2
|
26天前
|
Oracle 安全 关系型数据库
Oracle数据恢复—Oracle数据库误删除的数据恢复方法探讨
删除Oracle数据库数据一般有以下2种方式:delete、drop或truncate。下面针对这2种删除oracle数据库数据的方式探讨一下oracle数据库数据恢复方法(不考虑全库备份和利用归档日志)。
|
1月前
|
存储 Oracle 关系型数据库
Oracle同一台服务器创建多个数据库
【8月更文挑战第30天】在 Oracle 中,可在同一服务器上创建多个数据库。首先确保已安装 Oracle 软件并具有足够资源,然后使用 DBCA 工具按步骤创建,包括选择模板、配置存储及字符集等。重复此过程可创建多个数据库,需确保名称、SID 和存储位置唯一。创建后,可通过 Oracle Enterprise Manager 进行管理,注意服务器资源分配与规划。
38 10
|
10天前
|
SQL Oracle 关系型数据库
Oracle数据库管理:从入门到精通
表(Table):表是Oracle数据库中存储数据的基本结构单元,由行(Row)和列(Column)组成。每行代表一个记录,每列代表一个字段。 SQL(Structured Query Language):SQL是Oracle数据库的核心语言,用于与数据库交互,执行查询、插入、更新和删除等操作。 数据库实例与数据库:在Oracle中,数据库实例是一组后台进程和内存结构,用于管理数据库并提供服务。而数据库则是数据的物理存储,包括数据文件、控制文件、联机日志和参数文件等。
32 0
|
2月前
|
存储 Oracle 关系型数据库
分享几个Oracle数据库日常维护中常见的问题
分享几个Oracle数据库日常维护中常见的问题
84 1
|
2月前
|
SQL Oracle 关系型数据库
实时计算 Flink版产品使用问题之Oracle数据库是集群部署的,怎么进行数据同步
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
2月前
|
Oracle 关系型数据库 数据库
Oracle数据库备份脚本分享-Python
Oracle数据库备份脚本分享-Python
28 0

推荐镜像

更多
下一篇
无影云桌面