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

oracle临时表经常被锁_【赵强老师】Oracle数据库的存储结构相关推荐

  1. oracle临时表经常被锁_数据库学习——Oracle 数据库了解与使用

    一. 数据库相关概念 1 什么是数据库 所谓的数据库其实就是数据的集合.用户可以对集合中的数据进行新增.查询.更新.删除等操作.数据库是以一定方式储存在一起.能与多个用户共享.具有尽可能小的冗余度.与 ...

  2. oracle临时表经常被锁_这是一篇长篇入门级数据库讲解:oracle数据库数据导入导出步骤

    正如标题一样,本文内容主要介绍了浅谈入门级oracle数据库数据导入导出步骤,文章通过步骤解析介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧!!! ...

  3. oracle 锁表如何查看_【赵强老师】第一个Oracle的手工备份和恢复

    欢迎关注赵强老师微信公众号:myitshare 一.什么是手工管理的备份与恢复? 尽管在Oracle中,已经有了RMAN的备份与恢复.但是作为Oracle备份恢复的一种方式,我们将在本文中通过一个例子 ...

  4. oracle select 行数据_【赵强老师】什么是Oracle的数据字典?

    欢迎关注赵强老师微信公众号:myitshare 数据字典是oracle存放有关数据库信息的地方,几乎所有的系统信息和对象信息都可在数据字典中进行查询.数据字典是oracle数据库系统的信息核心,它是一 ...

  5. 视频教程-赵强老师:Oracle数据库从10g到11g(6)管理方案对象-Oracle

    赵强老师:Oracle数据库从10g到11g(6)管理方案对象 毕业于清华大学,拥有超过13年的工作经验. Oracle认证讲师,拥有6年以上授课经验.精通Oracle数据库.中间(Weblogic) ...

  6. 视频教程-赵强老师:Oracle数据库从10g到11g(4)PL/SQL编程基础-Oracle

    赵强老师:Oracle数据库从10g到11g(4)PL/SQL编程基础 毕业于清华大学,拥有超过13年的工作经验. Oracle认证讲师,拥有6年以上授课经验.精通Oracle数据库.中间(Weblo ...

  7. 赵强老师:Oracle数据库系列课程(12)管理数据库的存储结构与数据的并发-赵强老师-专题视频课程...

    赵强老师:Oracle数据库系列课程(12)管理数据库的存储结构与数据的并发-82人已学习 课程收益     从零开始学习Oracle数据库,让学员读整个Oracle数据库有个全面清除的认识和学习. ...

  8. 【赵强老师】Oracle RMAN脚本基础

    还是跟以往的风格一样,我们通过一个小视频先了解一下,如何使用RMAN进行数据库的备份和恢复. [赵强老师]Oracle RMAN脚本基础 RMAN在数据库服务器的帮助下实现数据库文件.控制文件.数据库 ...

  9. 视频教程-赵强老师:Oracle数据库从10g到11g(5)过程、函数和触发器-Oracle

    赵强老师:Oracle数据库从10g到11g(5)过程.函数和触发器 毕业于清华大学,拥有超过13年的工作经验. Oracle认证讲师,拥有6年以上授课经验.精通Oracle数据库.中间(Weblog ...

最新文章

  1. 2021年大数据Spark(二):四大特点
  2. html中怎么显示错误信息,在html中显示为内嵌错误的文本
  3. (十七)深入浅出TCPIP之HTTP和HTTPS
  4. Python基本操作(三)标准运算符与赋值
  5. 如何使用alt键+数字键盘上的数字键打出特殊符号
  6. 深度学习(四):高级卷积神经网络
  7. backtrack3安装使用教程
  8. Wincc语音报警 Wincc真人声音报警
  9. linux清除所有后台程序,Linux查看和关闭后台运行程序的方法
  10. 如何提高mysql的update速度_如何提高数据库update更新的速度
  11. 火狐插件Adblock Plus自定义功能屏蔽网易博客广告
  12. 微信卡劵、微信卡包,必须是认证订阅号或认证服务号
  13. 洛谷P1510-精卫填海(01背包)
  14. 人大金仓 日常命令 已解决
  15. 1001 害死人不偿命的(3n+1)猜想 (15分)_Quentin
  16. python 管线原理图_Q-Q图原理详解及Python实现
  17. c#调用matlab生成的dll
  18. 如何通过喂养菌群产生丁酸调节人体健康
  19. java 证书查看工具_程序员必备工具 Java证书工具Keytool的使用
  20. python多线程爬虫美女福利图片

热门文章

  1. vue+vant 移动端H5 商城项目_04
  2. 搭建 ELK 集群 kafka filebeat kibana logstash zookeeper elasticsearch
  3. Elasticsearch7.15.2 分布式集群安装(linux环境)
  4. Mongo 安装、配置、启动 Windows
  5. Git Flow工作流图
  6. 解决window的bat脚本执行出现中文乱码的问题
  7. 实战_06_SpringBoot整合redis-cluster集群版本
  8. 重学 VBA - 基础与实战篇(含正则表达式)
  9. redux中间件原理-讲义
  10. mysql union left join_Case:MySQL使用left join的时候or改写成union可以提高效率