网站首页 > 技术文章 正文
概述
学软件测试很多都会用到Oracle数据库,分享一篇关于Oracle数据库的存储结构。
Oracle数据库的存储结构分两类,分别是逻辑存储结构和物理存储结构。
逻辑存储结构
逻辑存储结构主要描述Oracle数据库的内部存储结构,即从技术概念上描述在Oracle数据库种如何组织、管理数据.因此,逻辑存储结构是和操作系统平台无关的,是由Oracle数据库创建和管理的.
从逻辑上来看.
- 数据库是由一个或者多个表空间等组成。
- 一个表空间(tablespace)由一组段组成,
- 一个段(segment)由一组区组成,
- 一个区(extent)由一批数据库块组成,
- 一个数据库块(block)对应一个或多个物理块
Database(数据库)
数据库是按照数据结构来组织、存储和管理数据的仓库。
Tablespaces(表空间)
表空间是数据库的逻辑划分,一个表空间只能属于一个数据库。表空间(tablespace)是最大的逻辑单位,对应一个或多个数据文件,通常由相关的段组成。表空间的大小是它所对应的数据文件大小的总和。所有的数据库对象都存放在指定的表空间中。但主要存放的对象是表, 所以称作表空间。
Segments (段):
一个段是分配给一个逻辑结构(一个表、一个索引或其他对象)的一组区,是数据库对象使用的空间的集合;段可以有表段、索引段、回滚段、临时段和高速缓存段等。Types of segments (段的类型详解)
extents (盘区)
是数据库存储空间分配的一个逻辑单位,它由连续数据块所组成。第一个段是由一个或多个盘区组成。当一段中间所有空间已完全使用,oracle为该段分配一个新的范围。
Data Block (数据块)
是oralce 管理数据文件中存储空间的单位,为数据库使用的I/O的最小单位,最小的逻辑部件,其大小可不同于操作系统的标准I/O块大小。数据块的大小由DB_BLOCK_SIZE参数确定。块尺寸是处理Oracle更新、选择、或者插入数据事务的最小单位。当用户从表中选择数据时,选择操作从数据库文件中以块为单位读取或者提取数据。例如Oracle块的大小为8kb,即使只想检索4kb的字符的名字,也必须读取含有这4个字符的整个8kb的块。
物理存储结构
Oracle物理存储结构组成:
- 数据文件(data file)、
- 联机日志文件(online redo log file)、
- 控制文件(control file)组成的、
- 归档日志文件、
- 参数文件、
- 警报文件、
- 跟踪文件、
- 备份文件
数据文件(data file):
一个数据库可以由多个数据文件组成的,数据文件是真正存放数据库数据的.一个数据文件就是一个操作系统文件.数据库的对象(表和索引)物理上是被存放在数据文件中的。当我们要查询一个表的数据的时候,如果该表的数据没有在内存中,那么oracle就要读取该表所在的数据文件,然后把数据存放到内存中.数据文件的特征是:
- 一个数据文件只能属于一个数据库.
- 数据文件可以被设置成自动增长.
- 一个或多个数据文件组成了表空间.
- 一个数据文件只能属于一个表空间.
控制文件(control file):
一个数据库至少要有一个控制文件,控制文件中存放的数据库的"物理结构信息",正是因为他存放的是数据库的物理结构信息,所以他就显得尤其的重要.这些物理结构信息就包括:
- 数据库的名字.
- 数据文件和联机日志文件的名字及位置.
- 创建数据库时的时间戳.
联机日志文件(online redo log file):
一个数据库可以有多个联机日志文件,联机日志文件包含了重做记录(undo records).联机日志文件记录了数据库的改变,例如当一次意外导致对数据的改变没有及时的写到数据文件中,那么oracle就会根据联机日志文件中 的信息获得这些改变,然后把这些改变写到数据文件中.这也是联机日志文件存在的意义.联机日志文件中重做记录的唯一功能就是用来做实例的恢复.比如,一次系统的意外掉电,导致内存中的数据没有被写到数据文件中.那么oralce就会根据联机日志文件中的重做记录功能包数据库恢复到失败前的状态.
归档日志文件(Archive log file):
是联机日志文件的副本,他记录了对数据库改变的历史.
参数文件(parameter file):
通常情况下指的就是初始化参数文件(initialization parameter file).参数文件包括了初始化参数文件和服务器端参数文件(server parameter file).在数据库启动的时候就会读取参数文件,然后根据参数文件中的参数来分配SGA并启动一系列的后台进程.参数文件中存放的是数据库和实例的参 数.
警报文件(alert log file):
就是警报日志文件,他记录了数据库的重大活动和所发生的错误.警报文件按照时间的先后来记录所发生的重大活动和错误.警报文件的名字的格式是 alertSID.log.警报文件的位置是由初始化参数background_dump_desc指定的.
跟踪文件(trace log file):
就是跟踪日志文件,每个服务器进程和后台进程都写跟踪文件.例如当后台进程发生了错误的时候,oracle就会把错误的信息写到跟踪文件中.DBA就可以根据跟踪文件的信息来查看进程中所发生的错误.跟踪文件被写到了两个目录中.和服务器进程有关的信息被写到了由初始化参数user_dump_desc指定的目录中,和后台进程有关信息被写到了由初始化参数background_dump_desc指定的目录中.伴随着时间跟踪文件就会被写满,DBA可以 手动来删除跟踪文件,也可以限制跟踪文件的大小.初始化参数MAX_DUMP_FILE_SIZE就可以限制跟踪文件的大小.
备份文件(backup file):
就是在数据库发生介质损坏的时候用来还原(restore)数据库的,恢复(recover)数据的.
上面讲的主要是Oracle的存储结构,对于我们软件测试的更重要是写sql,后面会分享下这方面的干货,觉得不错的朋友关注下喔~
猜你喜欢
- 2024-10-23 面试官:说说你对Oracle聚簇Cluster(B树聚簇)的一些看法?
- 2024-10-23 oracle数据库学习笔记 oracle数据库基础教程
- 2024-10-23 珍藏的ORACLE 体系结构详细图——逻辑结构+物理结构
- 2024-10-23 细说Oracle数据库与操作系统存储管理二三事
- 2024-10-23 【赵强老师】Oracle存储过程中的out参数
- 2024-10-23 oracle中怎么创建存储过程 oracle 创建存储过程,及调用
- 2024-10-23 从Oracle的SQL管理能力,看国产数据库差距
- 2024-10-23 Oracle存储过程模板 oracle存储过程视频教程
- 2024-10-23 Oracle学习笔记-存储过程与存储函数
- 2024-10-23 Oracle究竟有没有过时? oracle现在怎么样
你 发表评论:
欢迎- 551℃Oracle分析函数之Lag和Lead()使用
- 546℃几个Oracle空值处理函数 oracle处理null值的函数
- 543℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 537℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 534℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 522℃【数据统计分析】详解Oracle分组函数之CUBE
- 509℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 498℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端排序 (47)
- 前端密码加密 (47)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)