oracle: 表分区>>范围分区,列表分区,散列分区/哈希分区,间隔分区,参考分区,组合分区,子分区/复合分区/组合分区

ops/2025/2/5 6:26:56/

分区表

是将一个逻辑上的大表按照特定的规则划分为多个物理上的子表,这些子表称为分区。
分区可以基于不同的维度,如时间、数值范围、字符串值等,将数据分散存储在不同的分区
中,以提高数据管理的效率和查询性能,同时便于数据的维护和操作
作用

范围分区 range

它将表中的数据根据某个列的值的范围分布到不同的分区中。通常适用于具有连续数值或时间序列的数据

分区名自定义,可以用p1,p2,也可以用其他

分区字段必须在表中有定义, 每个分区的区间是前闭后开, 即最小值<=区间< 最大值

每个分区的最小值是上一个分区的最大值,相邻分区的区值是连续的

超出范围的数据无法被插入
解决方案: 设置一个默认分区, 超出其他分区数据范围的数据都会放入此分区, 但是此分区后面不能再增加分区

表分区list

 列表分区是根据列的值列表来分割数据的。每个分区包含一个或多个离散的列值,适用于数据基数小, 重复量大的情况. 各分区的值不用区分大小

插入数据时数据不在任何分区中会报错, 可以设置一个默认分区,专门存放类似数据

.......

partition  分区名 values (default)

散列分区/哈希分区 hash

语法2:

建表语句

partition by hash (字段)  partitions n

未指定分区名,数据库会自动设置分区名, n是分区个数

可利用数据字典查看分区的相关信息: 比如多少个分区,分区名称

SELECT * FROM ALL_TAB_PARTITIONS WHERE TABLE_NAME = UPPER('表名');

用于数据较少重复的, 以免数据倾斜

无需指定分区名, 数据库会自动设置分区名

虽然可以通过查询分区信息、查询特定分区的数据或通过实验验证来了解哈希分区的数据分布情况,但是无法直接通过分区键的值来确定数据会被分配到哪个分区, 所以工作中不常用

间隔分区

oarcle 11g 版本新增的分区类型,   间隔分区(Interval Partitioning)是范围分区(Range Partitioning)的一种特殊形式, 允许数据库自动创建分区以适应数据增长, 只需定义一个分区,系统会根据定义自动添加分区

注意: 间隔分区不能执行增加分区的操作

 

时间间隔函数

用于将数字转换为时间间隔类型

1. numtoyminterval  (n, 'year/month')

2.numtodsinterval (n, 'day/hour/minute/seconds')

通常用于日期计算或时间间隔操作

参考分区/引用分区

一个表的分区策略基于另一个表的分区键。这使得相关的表可以按照相同的逻辑进行分区,便于管理和维护, 这种分区方式特别适用于父子表关系,其中子表的分区与父表的分区保持一致

 子分区/复合分区

分区表可以进一步划分为子分区(Subpartitioning),从而形成复合分区(Composite Partitioning),有时也称为组合分区,混合分区

 

注意: 分区名称不能重复, 不在同一个分区里的子分区名也不能重复

分区管理

删除分区的写法2: delete from 表名 partition (分区名);

清空分区/截断分区(即删除分区中的所有数据)

默认是 保留存储空间。也就是说不写明时,Oracle 会保留分区占用的存储空间,以便后续可以重用这些空间来插入新数据

注意:

范围分区新增分区时,只能在最后一个分区后面添加

哈希分区/散列分区一般不添加分区

删除分区时, 如果只剩下一个分区, 不能删除唯一的分区(因为数据会重新分布,且不知道删除了哪些数据)

删除分区和截断分区都会把分区里面的数据删除, 不同的是截断分区的分区还在

合并分区

将多个分区合并为一个分区。合并分区通常用于优化存储或简化分区结构

注意: 确保合并操作不影响业务逻辑

索引维护: 合并分区后,全局索引可能会失效,需要使用 UPDATE INDEXES 子句来维护索引

语法

ALTER TABLE sales
MERGE PARTITIONS p1, p2
INTO PARTITION p_merged
[UPDATE INDEXES];

合并操作会停止间隔分区的自动创建功能,直到新的分区范围被定义。

对于参考分区/引用分区,如果父表的分区合并,子表的分区也会自动相应合并

拆分分区

把1个分区拆成2个或以上

范围分区的拆分语法


 列表分区的拆分语法

ALTER TABLE table_name
SPLIT PARTITION partition_name
values (value)
INTO (PARTITION new_partition1,PARTITION new_partition2
);

第一个分区包含分区字段的值,即(value)

范围分区和列表分区拆分语法的区别

范围分区:  at (value)

表分区: values(value) 

复合分区的拆分


http://www.ppmy.cn/ops/155796.html

相关文章

Nacos 的介绍和使用

1. Nacos 的介绍和安装 与 Eureka 一样&#xff0c;Nacos 也提供服务注册和服务发现的功能&#xff0c;Nacos 还支持更多元数据的管理&#xff0c; 同时具备配置管理功能&#xff0c;功能更丰富。 1.1. windows 下的安装和启动方式 下载地址&#xff1a;Release 2.2.3 (May …

2月3日星期一今日早报简报微语报早读

2月3日星期一&#xff0c;农历正月初六&#xff0c;早报#微语早读。 1、多个景区发布公告&#xff1a;售票数量已达上限&#xff0c;请游客合理安排行程&#xff1b; 2、2025春节档总票房破70亿&#xff0c;《哪吒之魔童闹海》破31亿&#xff1b; 3、美宣布对中国商品加征10…

Vue安装相关依赖冲突问题

问题出现 我在安装某一个依赖的时候&#xff0c;出现的问题。 npm install gcpaas/data-room-ui 报错原因 在使用vue/cli脚手架安装项目时&#xff0c;选择ESlint&#xff0c;再安装依赖包的时候&#xff0c;会报错。就是我上面的报错信息。 npm7版本之前遇到依赖冲突会忽视&…

Github 2025-02-04 Python开源项目日报 Top10

根据Github Trendings的统计,今日(2025-02-04统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目10TypeScript项目1Python中的算法实现集合 创建周期:2831 天开发语言:Python协议类型:MIT LicenseStar数量:178357 个Fork数量:…

5 前端系统开发:Vue2、Vue3框架(上):Vue入门式开发和Ajax技术

文章目录 前言一、Vue框架&#xff08;简化DOM操作的一个前端框架&#xff09;&#xff1a;基础入门1 Vue基本概念2 快速入门&#xff1a;创建Vue实例&#xff0c;初始化渲染&#xff08;1&#xff09;创建一个入门Vue实例&#xff08;2&#xff09;插值表达式&#xff1a;{{表…

fpga系列 HDL:XILINX Vivado ZYNQ-7000 PS-PL数据交互 AXI4 实现笔记

12_PL读写PS端DDR数据.mp4 打开AXI HP0 interface 参照HELLO WORLD新建Block Design&#xff0c;打开AXI HP0 interface,配置PL Fabric Clocks 时钟 添加转换模块 添加复位 添加时钟并进行连接 配置端口属性 连接复位后保存&#xff1a; 分配地址 代码 https://github.co…

c++ 一个类模拟黑盒测试!!

在软件开发中&#xff0c;我们经常需要对程序的输出进行验证&#xff0c;以确保其符合预期。为了实现这一目的&#xff0c;我们可以设计一个专门的类来封装输入、预期输出和实际输出的比较逻辑。本文将介绍一个经过修改的test类&#xff0c;它能够有效地用于程序的最终检查&…

手写单例模式

饿汉式加载模式&#xff08;线程安全&#xff09; 类一加载就创建对象&#xff0c;这种方式比较常用 优点&#xff1a;线程安全&#xff0c;没有加锁&#xff0c;执行效率高 缺点&#xff1a;不是懒加载&#xff0c;类初始化的时候就加载&#xff0c;浪费内存空间 package …