iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >【赵强老师】Oracle数据库的存储结构
  • 746
分享到

【赵强老师】Oracle数据库的存储结构

【赵强老师】Oracle数据库的存储结构 2019-11-21 03:11:41 746人浏览 绘本
摘要

oracle的存储结构分为:物理存储结构和逻辑存储结构。 一、物理存储结构:指硬盘上存在的文件 数据文件(data file) 一个数据库可以由多个数据文件组成的,数据文件是真正存放数据库数据的。一个数据文件就是一个操作系统文

【赵强老师】Oracle数据库的存储结构

oracle的存储结构分为:物理存储结构和逻辑存储结构。

一、物理存储结构:指硬盘上存在的文件

  • 数据文件(data file)

一个数据库可以由多个数据文件组成的,数据文件是真正存放数据库数据的。一个数据文件就是一个操作系统文件。数据库的对象(表和索引)物理上是被存放在数据文件中的。当我们要查询一个表的数据的时候,如果该表的数据没有在内存中,那么oracle就要读取该表所在的数据文件,然后把数据存放到内存中。通过下面的语句可以查看当前存在的数据文件和对应的表空间:

select file_name,tablespace_name from dba_data_files;

 

  •  联机日志文件(online redo log file)

一个数据库可以有多个联机日志文件,联机日志文件包含了重做记录(undo records).联机日志文件记录了数据库的改变,例如当一次意外导致对数据的改变没有及时的写到数据文件中,那么oracle就会根据联机日志文件中 的信息获得这些改变,然后把这些改变写到数据文件中.这也是联机日志文件存在的意义.联机日志文件中重做记录的唯一功能就是用来做实例的恢复.比如,一次系统的意外掉电,导致内存中的数据没有被写到数据文件中.那么oralce就会根据联机日志文件中的重做记录功能包数据库恢复到失败前的状态。可以通过下面的语句查看当前存在的日志文件和对应的日志组信息:

select member,group# from v$logfile;

 

 注意:Oracle使用日志组来管理日志文件。默认有三个日志组,每组中至少两个成员。如上图所示。

另外,我们已经知道了什么是数据文件和联机日志文件,通过下面的图解来说明他们之间的关系。

  •  控制文件(control file)

一个数据库至少要有一个控制文件,控制文件中存放的数据库的"物理结构信息",正是因为他存放的是数据库的物理结构信息,所以他就显得尤其的重要.这些物理结构信息就包括:

  1. 数据库的名字。
  2. 数据文件和联机日志文件的名字及位置。
  3. 创建数据库时的时间戳。
  4. RMAN备份的元信息

为了更好的保护数据库,我们可以镜像控制文件.每个控制文件中的内容就是相同的.镜像了控制文件,即使其中的一个控制文件出现了问题,也不会影响到数据库的损坏,数据的丢失. 在启动数据库的时候,oracle就会根据控制文件中的数据文件和联机日志文件的信息来打开数据库.

可以通过下面的语句查看当前存在的控制文件。

select name from v$controlfile;

 

 注意:这里默认有两个控制文件,这种方式叫做“多路复用”。

  • 归档日志文件

是联机日志文件的副本,他记录了对数据库改变的历史。注意:Oracle默认是非归档模式,可以通过下面的语句查看

arcHive log list;

 

 通过下面的语句,将数据库切换到归档模式。

shutdown immediate
startup mount
alter database archivelog;
alter database open;
  • 参数文件

通常情况下指的就是初始化参数文件(initialization parameter file).参数文件包括了初始化参数文件和服务器端参数文件(server parameter file).在数据库启动的时候就会读取参数文件,然后根据参数文件中的参数来分配SGA并启动一系列的后台进程.参数文件中存放的是数据库和实例的参数.

Oracle的参数文件有两种类型:

  1. Spfile:二进制形式,9i之后
  2. Pfile:文本形式,9i之前

可以通过下面的语句查看当前的参数文件信息:

show parameter spfile

 

可以使用下面的方式将spfile转换为pfile:

create pfile="/home/oracle/pfile.ora" from spfile;

 查看pfile中的参数值:

可以通过下面的语句修改参数的值。

alter system set open_cursors=400 scope=both;
注意:scope的取值有三个:memory、spfile、both 
  • 告警日志文件

记录了数据库的重大活动和所发生的错误.警报文件按照时间的先后来记录所发生的重大活动和错误.警报文件的名字的格式是 alert_SID.log。警报文件的位置可以通过查询v$diag_info得到,如下:

select * from v$diag_info;

 

注意:在12c以前的版本,告警日志的位置可以通过查询参数background_dump_dest得到。

告警日志文件中记录的信息,包括:

  1. 数据库启动和停止的信息
  2. 数据库的结构变化
  3. 强制审计的信息
  4. 的信息
  •  跟踪文件

就是跟踪日志文件,每个服务器进程和后台进程都写跟踪文件.例如当后台进程发生了错误的时候,oracle就会把错误的信息写到跟踪文件中.DBA就可以根据跟踪文件的信息来查看进程中所发生的错误。

跟踪文件的位置跟告警日志文件,在同一个目录下:

select * from v$diag_info;

 

  • 备份文件

就是在数据库发生介质损坏的时候用来还原(restore)数据库的,恢复(recover)数据的。

 

二、逻辑存储结构

从逻辑上来看,

  1. 数据库是由一个或者多个表空间等组成。
  2. 一个表空间(tablespace)由一组段组成
  3. 一个段(segment)由一组区组成
  4. 一个区(extent)由一批数据库块组成
  5. 一个数据库块(block)对应一个或多个物理块
  • Database(数据库)

数据库是按照数据结构来组织、存储和管理数据的仓库。

  • Tablespaces(表空间)

表空间是数据库的逻辑划分,一个表空间只能属于一个数据库。表空间(tablespace)是最大的逻辑单位,对应一个或多个数据文件,通常由相关的段组成。表空间的大小是它所对应的数据文件大小的总和。所有的数据库对象都存放在指定的表空间中。但主要存放的对象是表, 所以称作表空间。

必须存在的表空间

  • system
  • sysaux
  • temp
  • undo

可选的表空间:一般指用户创建的用户表空间,比如:users

可以通过下面的语句查看当前数据库的表空间信息:

select tablespace_name from dba_tablespaces;

 

  • Segments (段)

一个段是分配给一个逻辑结构(一个表、一个索引或其他对象)的一组区,是数据库对象使用的空间的集合;段可以有表段、索引段、回滚段、临时段和高速缓存段等。

  • extents (区)

是数据库存储空间分配的一个逻辑单位,它由连续数据块所组成。第一个段是由一个或多个盘区组成。当一段中间所有空间已完全使用,oracle为该段分配一个新的范围。

  • Data Block (数据块)

是oralce 管理数据文件中存储空间的单位,为数据库使用的I/O的最小单位,最小的逻辑部件,其大小可不同于操作系统的标准I/O块大小。数据块的大小由DB_BLOCK_SIZE参数确定。块尺寸是处理Oracle更新、选择、或者插入数据事务的最小单位。当用户从表中选择数据时,选择操作从数据库文件中以块为单位读取或者提取数据。例如Oracle块的大小为8kb,即使只想检索4kb的字符的名字,也必须读取含有这4个字符的整个8kb的块。

通过下面的语句查看当前数据块设置的大小:

show parameter db_block_size

 

 

 









 

您可能感兴趣的文档:

--结束END--

本文标题: 【赵强老师】Oracle数据库的存储结构

本文链接: https://www.lsjlt.com/news/5327.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • redis怎么存储结构化数据库
    Redis是一个键值存储系统,它并不是一个结构化数据库,但是可以使用一些技巧来存储结构化数据。1. 使用Hash数据结构:可以将结构...
    99+
    2023-09-05
    redis 数据库
  • 云数据库mongodb存储结构是什么
    在MongoDB中,数据以文档的形式存储,文档是MongoDB中的基本单元。文档是一个键值对的序列,类似于JSON对象。MongoD...
    99+
    2023-05-13
    云数据库mongodb 云数据库
  • 数据库的建筑师:使用 DDL 构建数据结构
    数据库中的数据结构是数据的骨架,它定义了数据的存储方式、组织形式和访问权限。使用数据定义语言 (DDL) 构建数据结构是数据库管理系统 (DBMS) 中的一项基本任务。本文将详细介绍 DDL 中用于创建、修改和删除数据结构的常用命令。 ...
    99+
    2024-02-19
    数据定义语言 DDL CREATE ALTER DROP 数据建模 数据结构
  • Oracle数据库的内存结构是什么
    这篇文章主要介绍“Oracle数据库的内存结构是什么”,在日常操作中,相信很多人在Oracle数据库的内存结构是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Oracle...
    99+
    2024-04-02
  • Python数据结构之图的存储结构详解
    一、图的定义 图是一种比树更复杂的一种数据结构,在图结构中,结点之间的关系是任意的,任意两个元素之间都可能相关,因此,它的应用极广。图中的数据元素通常被称为顶点 ( V e r t ...
    99+
    2024-04-02
  • Oracle数据库中的内存结构是什么
    Oracle数据库中的内存结构主要包括SGA(System Global Area)和PGA(Program Global Area...
    99+
    2024-03-02
    Oracle
  • mongodb数据存储结构是什么
    MongoDB的数据存储结构是基于文档模型的,它使用了一种称为BSON(Binary JSON)的二进制编码格式来表示和存储文档数据...
    99+
    2023-09-12
    mongodb
  • 【巨杉数据库Sequoiadb】LOB数据和结构化数据存储细节
    【 问题 描述】 晋商消 费 金融 测试 ,客 户 想了解以下的内容:  1. LOB 数据 读 取和写入的 过 ...
    99+
    2024-04-02
  • PHP数据结构之图存储结构的示例分析
    这篇文章主要介绍PHP数据结构之图存储结构的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!图的存储结构图的概念介绍得差不多了,大家可以消化消化再继续学习后面的内容。如果没有什么问题的话,我们就继续学习接下来的...
    99+
    2023-06-20
  • 如何理解大数据时代的结构化存储数据库HBase
    本篇文章为大家展示了如何理解大数据时代的结构化存储数据库HBase,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Hbase非常适合于非结构化数据存储的数据库,200...
    99+
    2024-04-02
  • MySQL中的数据存储结构是什么
    这篇文章主要介绍“MySQL中的数据存储结构是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL中的数据存储结构是什么”文章能帮助大家解决问题。 ...
    99+
    2023-02-14
    mysql
  • HBase中的数据存储结构是怎样的
    在HBase中,数据以表的形式进行存储,表由多行组成,每行可以有多个列族,每个列族可以包含多个列。每行都有一个唯一的行键,通过这个行...
    99+
    2024-04-09
    HBase
  • SQL Server数据存储结构是什么
    这期内容当中小编将会给大家带来有关SQL Server数据存储结构是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。文件类型  数据库在磁盘上是以文件为单位存储的,由数...
    99+
    2024-04-02
  • ThreadLocal数据存储结构原理解析
    目录一:简述二:TheadLocal的原理分析1.ThreadLocal的存储结构2.源码分析set()方法三:源码分析createMap()源码:流程图:expungeStaleE...
    99+
    2024-04-02
  • mysql数据库怎么用sql语句查询存储结构
    要查询 mysql 数据库存储结构,可以使用以下 sql 语句:show create table table_name;该语句将返回表的列定义和表选项的信息,包括列的名称、数据类型、约...
    99+
    2024-04-14
    mysql sql语句
  • Oracle数据库中的数据存储在哪里
    Oracle数据库中的数据存储在数据文件中。这些数据文件是存储在操作系统的文件系统中的,通常是以.dbf为扩展名的文件。Oracle...
    99+
    2024-04-09
    Oracle
  • C语言数据结构之线性表的链式存储结构
    1.什么是线性表的链式存储结构 —链表 存储结点:包括元素本身的信息,还有元素之间的关系逻辑的信息 这个结点有:数据域和指针域 一个指针域:指向后继结点, 单链表 二个指针域: 指向...
    99+
    2024-04-02
  • PostgreSQL数据库B-Tree索引的物理存储结构是怎样的
    这篇文章主要讲解了“PostgreSQL数据库B-Tree索引的物理存储结构是怎样的”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PostgreSQL数据库...
    99+
    2024-04-02
  • SQLServer的数据存储结构是什么样子的
    今天就跟大家聊聊有关SQLServer的数据存储结构是什么样子的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  SQLServer是一个数据库管理...
    99+
    2024-04-02
  • redis各种数据类型底层数据存储结构
    redis 的数据类型使用不同的底层存储结构:字符串:简单动态字符串(sds)哈希:哈希表,使用链表或跳跃表处理哈希碰撞列表:双向链表集合:哈希表或整数集合,使用布隆过滤器有序集合:跳跃...
    99+
    2024-04-19
    redis
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作