oracle学习笔记-存储空间管理(4)

2024-05-12 03:08

本文主要是介绍oracle学习笔记-存储空间管理(4),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

表空间将不同类型的数据对象组织在一起,一般情况下一个数据对象对应一个段。段由若干个区组成,区是存储分配和回收的基本单位。区由若干连续的数据块组成,数据块是逻辑结构中最小的存储单位,是oracle读写数据的基本单位。


一、段的管理
1、 段的类型

        查询数据字典dba_segments可以得到当前数据库中已经存在的段类型。
        
        TABLE 表段
        用于存储表中数据,创建表时自动创建一个同名表段。
        INDEX 索引段
       依赖于表的数据库对象。创建索引、定义主键约束和唯一性约束的时候将自动创建。
        临时段
       排序操作时将产生临时数据,临时数据首先存储在PGA排序区,PGA大小不够时将用到临时段。若没有专门的临时表空间,数据库服务器将SYSTEM表空间当做临时表空间。
        ROLLBACK 回滚段
       用来存储回滚数据。
        TABLE PARTITION 分区表段
       在数据库中可以将一个大表分成几个分区,每个分区对应一个段。这些分区表段可以存储在同一表空间也可以在不同表空间。
       主要应用于数据仓库,缩小数据库查询范围,加快查询速度。
        INDEX PARTITION 分区索引段
       将一个索引划分为多个分区,每个分区对应一个段。
        CLUSTER 簇段
       簇是一种数据库对象,将逻辑上相关的数据组织在一起,簇中的数据来自一个或多个表。创建簇时自动创建簇段。

2、 段的空间管理
       一般来说当创建一个数据库对象时,自动创建段,不需要用户创建。
       在创建本地管理表空间时可以使用SEGMENT SPACE MANAGEMENT子句指定段空间的管理方式。手工方式采用维护空闲列表的方式管理,自动方式则采用位图的方式管理。
       为了对段中的数据块的使用进行控制,在段中设置了一个HWM(HIGH WATER MARK)。
       HWM之上是未格式化不能使用的数据。HWM之下的数据情况如图:
 
        为给用户分配数据,设置了一个低HWM。分配数据时首先查找低HWM和HWM之间已被格式化的数据,如果不够,就将低HWM和HWM之间未格式化的数据格式化,如果依旧不够则HWM上移。


二、区的管理
1、 区的分配

        在本地管理表空间中,区的大小可指定AUTOALLOCATE由数据库服务器指定,或者由数据库管理员指定UNIFORM大小。当创建数据库对象时,数据库服务器为段分配相应数量的区,默认情况下只分配一个初始区,,尽管初始区还没有包含数据,但是不能分配给其他数据库对象。
可以通过数据字典dba_segments查看区的分配信息。一个段所占用区的详细信息可以通过查询数据字典DBA_EXTENTS获得。
2、 区的回收
        以下情况会发生区的回收:
         一个对象被删除
         对表进行整理
         对索引进行重建和合并
         执行TRUNCAT命令
         手工执行命令释放段中HWM以下未使用的空间

三、数据块的管理
        用户访问数据时,数据库服务器将数据从数据块读取到SGA高速缓存中,并放在与数据块大小相同的缓冲区中,然后再在缓冲区中对数据进行操作。
        Oracle中可以通过DB_BLOCK_SIZE定义标准块,也可通过DB_nK_BLOCK_SIZE定义非标准块,但是非标准块的大小不能和标准块大小相同。
1、 数据块的组成
        一个数据块由以下几方面组成:
         块头:记录块本身的信息,如块地址、段类型等;
         表目录:记录表的相关信息;
         行目录:记录行的相关信息;
         空闲空间
         已使用空间
2、 数据块的空间管理
        对数据块的管理主要涉及对空闲块的管理。当为数据库对象分配空间时,以区为单位,一个区有若干连续对的块,当一个区中一个块写满时就写入到下一个块,当一个区写满时就写入下一个区。
        每个数据库都留有一段保留空间,用来执行update操作,以减少块间的数据迁移。

        本地管理表空间,段的管理方式可以通过SEGMENT SPACE MANAGEMENT来指定自动管理方式AUTO或者手工管理MANUAL。自动管理方式为每个段维护一个位图,通过位图来管理段中的数据库,不需人工干预。在MANUAL模式下,每个段维护一个空闲列表,并以空闲列表的方式管理数据块,用户可以通过PCTFREE和PCTUSED参数来控制数据块空间的使用。具体用法如下图所示:


 

这篇关于oracle学习笔记-存储空间管理(4)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Oracle Expdp按条件导出指定表数据的方法实例

《OracleExpdp按条件导出指定表数据的方法实例》:本文主要介绍Oracle的expdp数据泵方式导出特定机构和时间范围的数据,并通过parfile文件进行条件限制和配置,文中通过代码介绍... 目录1.场景描述 2.方案分析3.实验验证 3.1 parfile文件3.2 expdp命令导出4.总结

SpringBoot使用minio进行文件管理的流程步骤

《SpringBoot使用minio进行文件管理的流程步骤》MinIO是一个高性能的对象存储系统,兼容AmazonS3API,该软件设计用于处理非结构化数据,如图片、视频、日志文件以及备份数据等,本文... 目录一、拉取minio镜像二、创建配置文件和上传文件的目录三、启动容器四、浏览器登录 minio五、

IDEA中的Kafka管理神器详解

《IDEA中的Kafka管理神器详解》这款基于IDEA插件实现的Kafka管理工具,能够在本地IDE环境中直接运行,简化了设置流程,为开发者提供了更加紧密集成、高效且直观的Kafka操作体验... 目录免安装:IDEA中的Kafka管理神器!简介安装必要的插件创建 Kafka 连接第一步:创建连接第二步:选

Oracle数据库执行计划的查看与分析技巧

《Oracle数据库执行计划的查看与分析技巧》在Oracle数据库中,执行计划能够帮助我们深入了解SQL语句在数据库内部的执行细节,进而优化查询性能、提升系统效率,执行计划是Oracle数据库优化器为... 目录一、什么是执行计划二、查看执行计划的方法(一)使用 EXPLAIN PLAN 命令(二)通过 S

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]