oracle 11g中如何快速设置表分区的自动增加

在很多业务系统中,一些大表一般通过分区表的形式来实现数据的分离管理,进而加快数据查询的速度。分区表运维管理的时候,由于人为操作容易忘记添加分区,导致业务数据写入报错。所以我们一般通过配置脚本或者利用oracle内置功能实现分区表分区的自动添加。

一、创建分区表

我们创建表tpc_part,为了模拟报错,我们设置以分钟为分区。

sql 复制代码
create table tpc_part
(
id number,
name varchar2(60),
address varchar2(100),
photo varchar2(20),
cjsj  date
)
partition by range(cjsj)
(
  partition part_tpc_2024121859 values less than (TO_DATE(' 2024-12-04 19:00:00','SYYYY-MM-DD HH24:MI:SS','NLS_CALENDAR=GREGORIAN'))
  tablespace DT_TPC_DAT,
  partition part_tpc_2024121900 values less than (TO_DATE(' 2024-12-04 19:01:00','SYYYY-MM-DD HH24:MI:SS','NLS_CALENDAR=GREGORIAN'))
  tablespace DT_TPC_DAT
);

二、写入数据

我们首先写入在分区内的数据,可以看到写入成功:

目前表只有两个分区,因为没有自动创建,我们写入不在其分区的数据,会提示报错:

三、添加自动分区

我们通过oracle 11g内置的自动化方法添加分区:

  • numtoyminterval(1,'YEAR') ------按一年分区
  • numtoyminterval(1,'MONTH') ------按一月分区
  • numtodsinterval(1,'DAY') ------按一天分区
  • numtodsinterval(1,'HOUR') ------按一小时分区
  • numtodsinterval(1,'MINUTE') ------按一分钟分区
  • numtodsinterval(1,'SECOND') ------按一秒分区

我们配置自己的分区表:

四、查看测试

我们继续测试刚才插入的数据,,可以发现表自动添加分区了。

sql 复制代码
SQL> insert into tpc_part values(2,'杜甫','中国北京','18200000000',to_date('2024-12-04 19:01:32','yyyy-mm-dd hh24:mi:ss'));
相关推荐
DokiDoki之父25 分钟前
Mybatis—入门 & (配置)SQL提示和日志输出
数据库·sql·mybatis
TDengine (老段)1 小时前
TDengine 数据函数 LN 用户手册
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
机灵猫1 小时前
Redis 在订单系统中的实战应用:防重、限流与库存扣减
数据库·redis·缓存
木易2.01 小时前
从零构建RAG知识库管理系统(二)
数据库·oracle
程序新视界1 小时前
什么是MySQL JOIN查询的驱动表和被驱动表?
数据库·后端·mysql
lingggggaaaa2 小时前
小迪安全v2023学习笔记(一百三十四讲)—— Windows权限提升篇&数据库篇&MySQL&MSSQL&Oracle&自动化项目
java·数据库·windows·笔记·学习·安全·网络安全
小光学长2 小时前
基于Vue的保护动物信息管理系统r7zl6b88 (程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
一匹电信狗2 小时前
【MySQL】数据库的相关操作
linux·运维·服务器·数据库·mysql·ubuntu·小程序
TDengine (老段)4 小时前
连接 TDengine 遇到报错 “failed to connect to server, reason: Connection refused” 怎么办?
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
李慕婉学姐5 小时前
Springboot黄河文化科普网站5q37v(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端