oracle-存储结构

文件包括

控制文件.ctl、数据文件.dbf、日志文件.log这三类放在存储上。

参数文件:空间的划分,进程的选用(.ora)

oracle启动的时候需要读一下,数据库启动后,参数文件并不关闭,但即使文件丢了,数据库也没影响。

备份文件:主要备份数据文件和归档日志文件,一定不能放在存储上,存储出问题,数据文件和归档都没了,数据丢失。放在带库上(虚拟的和真实的都可以)

归档日志文件:离线文件

口令文件:远程需要,丢失也无所谓,可以临时生成

预警日志:alert,重大错误记录,checkpoint

跟踪文件:trc,进程出问题记录

表空间

数据库、表空间、段、区、块

一个表空间由一个或多个文件组成

在表和数据文件之间的一个中间层

系统级别的:system,sysaux,这两个都是系统和数据字典相关的,undo,temp

user虽然是用户的,但实际中也不用,自己建立

方案其实就是用户的概念,schema

段区块

一般8个块是一个区,每次段用满了,就分配一个区

表空间创建可以用em,也可以sql


区管理选本地,段管理自动

对表进行分析,分析后,上面的sql数值更准确

高水位线

假设一个表中有1000条数据,然后删除了500条数据,表的高水位线仍然会保持在1000条数据的位置。这意味着即使删除了一半的数据,表所占用的存储空间仍然会保持在删除前的大小。

要降低高水位线,可以采取以下几种方法:

压缩表:使用Oracle提供的压缩表功能,可以将表的高水位线调整到合理的位置,回收被删除数据所占用的存储空间。

重建表:通过备份表数据,删除原表,然后重新创建表并将备份数据重新插入表中,可以有效地降低高水位线。

重新组织表空间:通过重新组织表空间,可以将表的高水位线重新设置到合理的位置,回收被删除数据所占用的存储空间。

这些方法可以帮助降低高水位线,回收被删除数据所占用的存储空间,从而减少存储空间的浪费。

全表扫面:扫面高水位线以下的所有空间

oracle块物理结构

行链接:尽量一行放在一个block中,但如果放不下,那就链接的方式存放

行迁移:当更新行时,当前block放不下,只能放到别的block中,当前位置不移除,而是写新地方的地址

相关推荐
小猪咪piggy3 分钟前
【JavaEE】(23) 综合练习--博客系统
java·数据库·java-ee
bikong713 分钟前
一种高效绘制余晖波形的方法Qt/C++
数据库·c++·qt
一叶飘零_sweeeet15 分钟前
从 0 到 1 攻克订单表分表分库:亿级流量下的数据库架构实战指南
java·数据库·mysql·数据库架构·分库分表
xianyinsuifeng30 分钟前
Oracle 10g → Oracle 19c 升级后问题解决方案(Pro*C 项目)
c语言·数据库·oracle
TDengine (老段)36 分钟前
TDengine 选择函数 First 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
dreams_dream1 小时前
企业级 Django 日志配置示例
数据库·django·sqlite
络72 小时前
Redis 非缓存核心场景及实例说明
数据库·redis·缓存
计算机学长felix2 小时前
基于Django的“酒店推荐系统”设计与开发(源码+数据库+文档+PPT)
数据库·python·mysql·django·vue
GBASE3 小时前
ITPUB专访南大通用——GBase 8s数据库以内核铸根基,以生态赢未来
数据库
GBASE3 小时前
GBASE南大通用技术分享:构建最优数据平台,GBase 8s数据库安装准备(二)
数据库