【云原生进阶之数据库技术】第二章-Oracle-原理-4.2.3-数据文件解析

本文主要是介绍【云原生进阶之数据库技术】第二章-Oracle-原理-4.2.3-数据文件解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 数据文件

        在操作系统层面,Oracle 数据库将数据存储在数据文件中。Oracle 数据库必须至少有一个数据文件。数据文件是数据库中所有数据的实际存储空间,所有数据文件大小的和构成了数据库的大小。根据数据信息类型不同,数据文件分为永久性数据文件和临时数据文件两种。

1.1 数据文件的用途

        每个未分区的 schema 对象(比如表、索引)、对象的每个分区都存储在自己的段(segment)中。每个段都只属于一个表空间(tablespace)。表空间和数据文件存在以下重要区别:

  1. 每个表空间由一个或多个数据文件组成;
  2. 一个数据库的所有数据都存储在数据库表空间的数据文件中;
  3. 一个段可以跨越一个或多个数据文件,但是不能跨越多个表空间;
  4. 一个Oracle数据库必须有 SYSTEM 和 SYSAUX 这两个表空间。在数据库创建时,Oracle 会自动为 SYSTEM 表空间分配第一批数据文件。SYSTEM 表空间中存有数据字典(data dictionary),即包含数据库元数据的表的一个集合。通常,Oracle 数据库还会有一个 undo 表空间和一个临时表空间(一般命名为 TEMP)。

        下图展示了表空间、数据文件和段之间的关系。

图1 数据文件和表空间

schema对象:Tables and Table Clusters

1.2 数据文件特征

        每一个ORACLE数据库有一个或多个物理的数据文件(data file)。一个数据库的数据文件包含全部数据库数据。逻辑数据库结构(如表、索引)的数据物理地存储在数据库的数据文件中。数据文件有下列特征: 

  1. 一个数据文件仅与一个数据库联系。
  2. 一个数据文件只能属于一个数据库
  3. 数据文件可以被设置成自动扩展
  4. 一个或多个数据文件形成一个表空间
  5. 一个数据文件只能属于一个表空间 

        数据文件中的数据在需要时可以读取并存储在ORACLE内存储区中。例如:用户要存取数据库一表的某些数据,如果请求信息不在数据库的内存存储区内,则从相应的数据文件中读取并存储在内存。当修改和插入新数据时,不必立刻写入数据文件。为了减少磁盘输出的总数,提高性能,数据存储在内存,然后由ORACLE后台进程DBWR决定如何将其写入到相应的数据文件。

        查看数据文件:

#方式1:SQL> select name from v$datafile;#方式2:SQL> select file_name from dba_data_files;

1.3 永久数据文件 vs 临时数据文件

        永久表空间(permanent tablespace)包含有持久化的 schema 对象,存储在永久数据文件中。

        临时表空间(temporary tablespace)中的 schema 对象只存在于一个 session 中。在本地管理的临时表空间包含有临时文件(temp files),用于存储哈希、排序等操作中的数据。当内存空间不够时,临时文件也会用来存储查询操作的结果集数据。

        临时文件与永久数据文件相似,但存在以下区别:

  1. 永久数据库对象,比如表,不会存储在临时文件中;
  2. 临时文件一直被设定为 NOLOGGING 模式,即不会产生 redo日志。介质恢复过程中也不会识别临时文件;
  3. 临时文件不能被设置为只读;
  4. 不能使用 ALTER DATBASE 命令来创建临时文件;
  5. 当你创建或者改变临时文件的大小时,Oracle 并不会保证会给临时文件分配到指定文件大小的磁盘空间。在 Linux 和 Unix 操作系统中,临时文件会被创建为稀疏文件(sparse files)。即只有当数据块被首次访问时才会给临时文件分配磁盘空间,而不是在创建或者 resize 临时文件时就分配。
  6. 临时文件的信息可以在数据字典视图 DBA_TEMP_FILES 和 动态性能视图 V$TEMPFILE 中查看,但无法在 DBA_DATA_FILES 或 V$DATAFILE 视图中看到。

1.4 在线数据文件 vs 离线数据文件

        数据文件有在线(可用)和离线(不可用)两种状态。数据库无法访问离线的数据文件。当要进行离线备份或者发生数据块损坏时,就可以将数据文件离线。如果数据库无法向一个数据文件写入数据,就会自动将该数据文件离线。

        与数据文件类似,表空间也有在线和离线两种状态。如果将一个在线表空间中的一个数据文件离线,该表空间本身仍然会保持在线状态。当我们将一个表空间离线,该表空间内的所有数据文件都会暂时不可用。

        从 Oracle 12c 开始,在数据库打开时,可以使用 ALTER DATABASE MOVE DATAFILE 语句将一个在线的数据文件从所在的物理文件迁移到另一个物理文件。该功能可以在以下场景中使用:

  1. 将表空间从一种存储中迁移到另一种存储中;
  2. 将很少被访问的数据文件迁移到开销低的存储中;
  3. 将表空间设置为只读后,将其中的数据文件迁移到 write-once 存储中,比如 WORM (write once read many)驱动(一次性写入后不可删除和修改);
  4. 将数据库迁移到 Oracle ASM。

1.5 数据文件结构

        在创建数据文件时,除了分配指定的磁盘空间以外,还会加上数据文件 header 的大小。数据文件 header 中包含有该数据文件的元数据,比如数据文件大小和检查点 SCN(checkpoint system change number, Checkpoint SCN)。每个数据文件 header 都包含一个绝对文件编号(用于在数据库中唯一标识该数据文件)和一个相对文件编号(用于在表空间中唯一标识该数据文件)。

        创建数据文件时,分配的磁盘空间会被格式化但是尚未存储用户数据。这部分磁盘空间会被保留给相关表空间中将来存储数据的 segment。随着表空间的数据增长,Oracle 会将数据文件中的剩余空间用来给 segment 分配区(extent)。

        下图展示了数据文件中的不同空间。

图2 数据文件中的空间

参考链接

Oracle架构_数据库底层原理、机制 (授人以渔)_oracle底层-CSDN博客

Oracle原理大图-CSDN博客

oracle体系结构详解

一篇文章带你了解Oracle的体系结构

ORACLE体系结构逻辑结构-表空间、段、区和数据块 - 知乎

oracle数据库体系架构详解

Oracle数据库体系结构 

Oracle架构、原理、进程-腾讯云开发者社区-腾讯云

oracle 数据库体系结构详解_oracle体系结构详解-CSDN博客

Oracle系列十九:Oracle的体系结构_oracle体系结构-CSDN博客

一篇文章带你了解Oracle的体系结构

Oracle数据库体系结构 

oracle 数据库体系结构详解_oracle体系结构详解-CSDN博客

Oracle数据库体系结构(二)_物理结构_oracle数据连接-CSDN博客

Oracle物理存储结构

Oracle数据库存储结构:物理存储结构_oracle的物理结构-CSDN博客

Oracle数据库的体系结构(上)——存储结构_oracle存储结构管理-CSDN博客

Oracle第八节-Oracle物理存储结构_orcale物理文件-CSDN博客

【数据库】Oracle存储结构

一篇文章带你了解Oracle底层物理与逻辑存储 - 知乎

Oracle数据库,详解Oracle物理存储结构-腾讯云开发者社区-腾讯云

Oracle理论篇专栏

这篇关于【云原生进阶之数据库技术】第二章-Oracle-原理-4.2.3-数据文件解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1017977

相关文章

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

PLsql Oracle 下载安装图文过程详解

《PLsqlOracle下载安装图文过程详解》PL/SQLDeveloper是一款用于开发Oracle数据库的集成开发环境,可以通过官网下载安装配置,并通过配置tnsnames.ora文件及环境变... 目录一、PL/SQL Developer 简介二、PL/SQL Developer 安装及配置详解1.下

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

查询SQL Server数据库服务器IP地址的多种有效方法

《查询SQLServer数据库服务器IP地址的多种有效方法》作为数据库管理员或开发人员,了解如何查询SQLServer数据库服务器的IP地址是一项重要技能,本文将介绍几种简单而有效的方法,帮助你轻松... 目录使用T-SQL查询方法1:使用系统函数方法2:使用系统视图使用SQL Server Configu

SQL Server数据库迁移到MySQL的完整指南

《SQLServer数据库迁移到MySQL的完整指南》在企业应用开发中,数据库迁移是一个常见的需求,随着业务的发展,企业可能会从SQLServer转向MySQL,原因可能是成本、性能、跨平台兼容性等... 目录一、迁移前的准备工作1.1 确定迁移范围1.2 评估兼容性1.3 备份数据二、迁移工具的选择2.1

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查