Oracle 普通表至分区表的分区交换

交换分区

这种方法只是对数据字典中分区和表的定义进行了修改,没有数据的修改或复制,效率最高。适用于包含大数据量的表转到分区表中的一个分区的操作。尽量在业务空闲的时候进行操作。

交换分区的操作步骤如下

1、创建分区表p_tb,假设有2个分区,P1,P2.

2、创建表tb_p1存放P1规则的数据。

3、创建表tb_p2 存放P2规则的数据。

4、用表tb_p1 和P1 分区交换,把表tb_p1的数据放到到P1分区

5、用表tb_p2和P2 分区交换,把表tb_p2的数据存放到P2分区。

测试交换

创建分区表:

create table p_tb

(id number,time date)

partition by range(time)

(

partition p1 values less than (to_date('2024-02-01', 'yyyy-mm-dd')),

partition p2 values less than (to_date('2024-03-01', 'yyyy-mm-dd'))

);

创建2个分别对应分区的基表并插入数据:

CREATE TABLE tb_p1(id number,t_time date);

CREATE TABLE tb_p2(id number,t_time date);

insert into tb_p1 values(1,to_date('2024-01-10','YYYY-MM-DD'));

insert into tb_p1 values(2,to_date('2024-01-20','YYYY-MM-DD'));

insert into tb_p2 values(1,to_date('2024-02-10','YYYY-MM-DD'));

insert into tb_p2 values(2,to_date('2024-02-20','YYYY-MM-DD'));

commit;

将2个普通表与2个分区进行交换:

alter table p_tb exchange partition p1 with table tb_p1;

alter table p_tb exchange partition p2 with table tb_p2;

查询2个分区交换后的数据:

select count(*) from p_tb partition(p1);

COUNT(*)


2

select count(*) from p_tb partition(p2);

COUNT(*)


2
注意:看到交换后数据和之前的基表数据一致。

在查询原来的2个基表,发现数据已经没有了,数据已经交换至分区表对应的分区:

select count(*) from tb_p2;

COUNT(*)


0

select count(*) from tb_p1;

COUNT(*)


0

注意:一般情况下,我们在创建分区表的时候,都会创建一个MAX分区,用来存放不匹配分区规则的数据。这里我只创建了2个分区,没有创建maxvalue分区。 现在我来插入一条不满足规则的数据,看结果 :

insert into p_tb values(3,to_date('2024-03-10','yyyy-mm-dd'));

*

第 1 行出现错误:

ORA-14400: 插入的分区关键字未映射到任何分区
注意:如果插入的数据不满足分区规则,并且没有MAX分区则会会报 ORA-14400 错误。

相关推荐
RunningShare21 小时前
基于Flink的AB测试系统实现:从理论到生产实践
大数据·flink·ab测试
IT 小阿姨(数据库)21 小时前
PostgreSQL通过pg_basebackup物理备份搭建流复制备库(Streaming Replication Standby)
运维·服务器·数据库·sql·postgresql·centos
小蒜学长1 天前
springboot基于javaweb的小零食销售系统的设计与实现(代码+数据库+LW)
java·开发语言·数据库·spring boot·后端
云边有个稻草人1 天前
从内核调优到集群部署:基于Linux环境下KingbaseES数据库安装指南
linux·数据库·金仓数据库管理系统
EnCi Zheng1 天前
JPA 连接 PostgreSQL 数据库完全指南
java·数据库·spring boot·后端·postgresql
Raymond运维1 天前
MySQL包安装 -- RHEL系列(Yum资源库安装MySQL)
linux·数据库·mysql
Jolie_Liang1 天前
保险业多模态数据融合与智能化运营架构:技术演进、应用实践与发展趋势
大数据·人工智能·架构
他们叫我技术总监1 天前
Oracle数据库常见问题实战:从连接错误到自动清理空闲会话
数据库·oracle
武子康1 天前
大数据-118 - Flink 批处理 DataSet API 全面解析:应用场景、代码示例与优化机制
大数据·后端·flink
文火冰糖的硅基工坊1 天前
《投资-78》价值投资者的认知升级与交易规则重构 - 架构
大数据·人工智能·重构