Oracle增加表分区

一、首先我们讲一下表分区的优缺点

表分区有以下优点:
1、改善查询性能:对分区对象的查询可以仅搜索自己关心的分区,提高检索速度。
2、增强可用性:如果表的某个分区出现故障,表在其他分区的数据仍然可用;
3、维护方便:如果表的某个分区出现故障,需要修复数据,只修复该分区即可;
4、均衡I/O:可以把不同的分区映射到磁盘以平衡I/O,改善整个系统性能。

缺点:
分区表相关:已经存在的表没有方法可以直接转化为分区表。不过 Oracle 提供了在线重定义表的功能。

二、如何添加表分区

页面日志显示不出来,查看后台log信息显示

Caused by: Error : 14400, Position : 0, 
Sql = insert into DSGC_LOG_BODY_PAYLOAD(pl_id,track_id,payload_data,creation_date,created_by,last_update_date,last_updated_by) values(:1 ,:2 ,:3 ,:4 ,'-1',:5 ,'-1'), 
OriginalSql = insert into DSGC_LOG_BODY_PAYLOAD(pl_id,track_id,payload_data,creation_date,created_by,last_update_date,last_updated_by) values(?,?,?,?,'-1',?,'-1'), 
Error Msg = ORA-14400: inserted partition key does not map to any partition

这里提示DSGC_LOG_BODY_PAYLOAD问题出在这个表
然后就去连接Oracle数据库看以一下表分区

在这里插入图片描述这里发现表分区没有了所以页面日志是显示不出来的,我们就要增加表分区,以下是一月一增
加分区的时候注意 partition P_202204和TO_DATE(‘2022-05-01 00:00:00’
以下4条自己研究以下找下规律

alter table  DSGC_LOG_BODY_PAYLOAD add partition P_202201 values less than
(TO_DATE('2022-02-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')) tablespace DSGC_LOG_REC_PINITED;

alter table  DSGC_LOG_BODY_PAYLOAD add partition P_202204 values less than
(TO_DATE('2022-05-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')) tablespace DSGC_LOG_REC_PINITED;

alter table  DSGC_LOG_BODY_PAYLOAD add partition P_202205 values less than
(TO_DATE('2022-06-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')) tablespace DSGC_LOG_REC_PINITED;

alter table  DSGC_LOG_BODY_PAYLOAD add partition P_202212 values less than
(TO_DATE('2023-01-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')) tablespace DSGC_LOG_REC_PINITED;

根据需求进行添加,添加好后查看表分区

在这里插入图片描述这样就添加好了,再去查看页面日志就可以正常显示了

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐