GBASE南大通用技术分享:GBase 8c 数据库分区表实践探秘(五)

本文继续介绍南大通用GBase 8c 数据库第四种分区类型。

4. 间隔分区表

间隔分区是范围分区的扩展,支持自动创建新分区。

适用场景

间隔分区特别适合:

  • 按时间自动增长的数据,如日志、监控数据
  • 无法预先确定分区范围的场景
  • 需要减少分区维护工作量的应用

语法格式

方式一:START(partition_value) END (partition_value | MAXVALUE)方式

sql 复制代码
CREATE TABLE partition_table_name
( [column_name data_type ]
[, ... ]
)
    PARTITION BY RANGE (partition_key) 
        (
          INTERVAL ('interval_expr') 
          PARTITION partition_name START(partition_value) END (partition_value | MAXVALUE)
          [, ... ]
        ); 

方式二:START(partition_value) END (partition_value) EVERY (interval_value)方式

sql 复制代码
CREATE TABLE partition_table_name
( [column_name data_type ]
[, ... ]
)
    PARTITION BY RANGE (partition_key)  
        (
          PARTITION partition_name START(partition_value) END (partition_value) EVERY (interval_value)
          [, ... ]  
        ); 

方式三:START(partition_value)方式

sql 复制代码
CREATE TABLE partition_table_name
( [column_name data_type ]
[, ... ]
)
    PARTITION BY RANGE (partition_key)  
        (
          INTERVAL ('interval_expr') 
          PARTITION partition_name START(partition_value) 
          [, ... ]  
        ); 

方式四:END(partition_value | MAXVALUE)方式

sql 复制代码
CREATE TABLE partition_table_name
( [column_name data_type ]
[, ... ]
)
    PARTITION BY RANGE (partition_key)  
        INTERVAL ('interval_expr') 
        (
          PARTITION partition_name END(partition_value | MAXVALUE) 
          [, ... ]  
        );

SQL示例

sql 复制代码
drop table if exists t_auto_create_partition;
create table t_auto_create_partition (
   r_id varchar(32) not null,
   s_id varchar(200),
   r_ratio varchar(100),
   create_time timestamp without time zone default localtimestamp not null
) partition by range ("create_time") interval ('1 month') 
(
   partition p1 values less than('2020-01-01 00:00:00')
);
-- 插入测试数据
INSERT INTO t_auto_create_partition (r_id, s_id, r_ratio, create_time)
VALUES
   ('1', 's1', 'ratio1', '2020-01-01 10:00:00'),
   ('2', 's2', 'ratio2', '2021-02-01 10:00:00'),
   ('22', 's22', 'ratio2', '2021-02-03 10:00:00'),
   ('3', 's3', 'ratio3', '2022-03-01 10:00:00'),
   ('4', 's4', 'ratio4', '2023-04-01 10:00:00'),
   ('5', 's5', 'ratio5', '2024-05-01 10:00:00'),
   ('6', 's6', 'ratio6', '2025-06-01 10:00:00'),
   ('7', 's7', 'ratio7', '2020-03-06 10:00:00'),
   ('8', 's8', 'ratio8', '2019-07-04 10:00:00')
;
-- 查询数据
SELECT * FROM t_auto_create_partition ;
-- 查询分区数据
select * from t_auto_create_partition partition(p1);
select * from t_auto_create_partition partition(sys_p7);
-- 删除分区
alter table t_auto_create_partition drop partition sys_p3;
-- 分裂分区(B模式不支持): sys_p5 分割为 sys_p5_1,sys_p5_2
ALTER TABLE t_auto_create_partition SPLIT PARTITION sys_p5 AT('2024-05-15 00:00:00') INTO (PARTITION sys_p5_1,PARTITION sys_p5_2);
-- 合并分区(B模式不支持):将sys_p5_1,sys_p5_2 合并为sys_p5_3
ALTER TABLE t_auto_create_partition MERGE PARTITIONS sys_p5_1,sys_p5_2 INTO PARTITION sys_p5_3;
-- 重命名分区:将sys_p7 改成 sys_p8
ALTER TABLE t_auto_create_partition rename PARTITION sys_p7 to sys_p8;
-- 查看分区表信息
SELECT relname, boundaries::varchar FROM pg_partition p where p.parentid='t_auto_create_partition'::regclass order by 1;

5. 实际应用建议

分区键选择原则:1) 选择经常作为查询条件的列;2) 选择数据分布均匀的列;3) 避免选择频繁更新的列;4) 考虑业务数据的自然边界。

为了提升性能,本文总结了一些优化建议:

  • 结合分区键建立本地索引
  • 定期检查和维护分区统计信息
  • 移除不再需要的过期分区
  • 监控分区数据分布均匀性
相关推荐
短剑重铸之日15 小时前
《7天学会Redis》Day 4 - 高可用架构设计与实践
数据库·redis·缓存
NineData15 小时前
第三届数据库编程大赛-八强决赛成绩揭晓
数据库·算法·代码规范
難釋懷15 小时前
认识Redis
数据库·redis·缓存
超级种码15 小时前
Redis:Redis脚本
数据库·redis·缓存
想唱rap15 小时前
表的约束条件
linux·数据库·mysql·ubuntu·bash
超级种码15 小时前
Redis:Redis 命令详解
数据库·redis·bootstrap
qq_4017004116 小时前
Qt 事件处理机制
java·数据库·qt
Elastic 中国社区官方博客16 小时前
使用 jina-embeddings-v3 和 Elasticsearch 进行多语言搜索
大数据·数据库·人工智能·elasticsearch·搜索引擎·全文检索·jina
深海小黄鱼16 小时前
mysql 导入csv文件太慢, Error Code: 1290.
数据库·mysql
小宇的天下16 小时前
Calibre Connectivity Extraction(21-1)
数据库·oracle