云数据库 GaussDB-二级分区
时间:2025-01-26 10:39:12
二级分区
二级分区(Sub Partition,也叫组合分区)是基本数据分区类型的组合,将表通过一种数据分布方法进行分区,然后使用第二种数据分布方式将每个分区进一步细分为子分区。给定分区的所有子分区表示数据的逻辑子集。常见的二级分区组合如下所示:
- Range-Range
- Range-List
- Range-Hash
- List-Range
- List-List
- List-Hash
- Hash-Range
- Hash-List
- Hash-Hash
示例如下:
gaussdb=# --Range-RangeCREATE TABLE t_range_range ( c1 INT, c2 INT, c3 INT)PARTITION BY RANGE (c1) SUBPARTITION BY RANGE (c2) ( PARTITION p1 VALUES LESS THAN (10) ( SUBPARTITION p1sp1 VALUES LESS THAN (5), SUBPARTITION p1sp2 VALUES LESS THAN (10) ), PARTITION p2 VALUES LESS THAN (20) ( SUBPARTITION p2sp1 VALUES LESS THAN (15), SUBPARTITION p2sp2 VALUES LESS THAN (20) ));DROP TABLE t_range_range;--Range-ListCREATE TABLE t_range_list ( c1 INT, c2 INT, c3 INT)PARTITION BY RANGE (c1) SUBPARTITION BY LIST (c2) ( PARTITION p1 VALUES LESS THAN (10) ( SUBPARTITION p1sp1 VALUES (1, 2), SUBPARTITION p1sp2 VALUES (3, 4) ), PARTITION p2 VALUES LESS THAN (20) ( SUBPARTITION p2sp1 VALUES (1, 2), SUBPARTITION p2sp2 VALUES (3, 4) ));DROP TABLE t_range_list;--Range-HashCREATE TABLE t_range_hash ( c1 INT, c2 INT, c3 INT)PARTITION BY RANGE (c1) SUBPARTITION BY HASH (c2) SUBPARTITIONS 2( PARTITION p1 VALUES LESS THAN (10), PARTITION p2 VALUES LESS THAN (20));DROP TABLE t_range_hash;--List-RangeCREATE TABLE t_list_range ( c1 INT, c2 INT, c3 INT)PARTITION BY LIST (c1) SUBPARTITION BY RANGE (c2) ( PARTITION p1 VALUES (1, 2) ( SUBPARTITION p1sp1 VALUES LESS THAN (5), SUBPARTITION p1sp2 VALUES LESS THAN (10) ), PARTITION p2 VALUES (3, 4) ( SUBPARTITION p2sp1 VALUES LESS THAN (5), SUBPARTITION p2sp2 VALUES LESS THAN (10) ));DROP TABLE t_list_range;--List-ListCREATE TABLE t_list_list ( c1 INT, c2 INT, c3 INT)PARTITION BY LIST (c1) SUBPARTITION BY LIST (c2) ( PARTITION p1 VALUES (1, 2) ( SUBPARTITION p1sp1 VALUES (1, 2), SUBPARTITION p1sp2 VALUES (3, 4) ), PARTITION p2 VALUES (3, 4) ( SUBPARTITION p2sp1 VALUES (1, 2), SUBPARTITION p2sp2 VALUES (3, 4) ));DROP TABLE t_list_list;--List-HashCREATE TABLE t_list_hash ( c1 INT, c2 INT, c3 INT)PARTITION BY LIST (c1) SUBPARTITION BY HASH (c2) SUBPARTITIONS 2( PARTITION p1 VALUES (1, 2), PARTITION p2 VALUES (3, 4));DROP TABLE t_list_hash;--Hash-RangeCREATE TABLE t_hash_range ( c1 INT, c2 INT, c3 INT)PARTITION BY HASH (c1) PARTITIONS 2SUBPARTITION BY RANGE (c2) ( PARTITION p1 ( SUBPARTITION p1sp1 VALUES LESS THAN (5), SUBPARTITION p1sp2 VALUES LESS THAN (10) ), PARTITION p2 ( SUBPARTITION p2sp1 VALUES LESS THAN (5), SUBPARTITION p2sp2 VALUES LESS THAN (10) ));DROP TABLE t_hash_range;--Hash-ListCREATE TABLE t_hash_list ( c1 INT, c2 INT, c3 INT)PARTITION BY HASH (c1) PARTITIONS 2SUBPARTITION BY LIST (c2) ( PARTITION p1 ( SUBPARTITION p1sp1 VALUES (1, 2), SUBPARTITION p1sp2 VALUES (3, 4) ), PARTITION p2 ( SUBPARTITION p2sp1 VALUES (1, 2), SUBPARTITION p2sp2 VALUES (3, 4) ));DROP TABLE t_hash_list;--Hash-HashCREATE TABLE t_hash_hash ( c1 INT, c2 INT, c3 INT)PARTITION BY HASH (c1) PARTITIONS 2SUBPARTITION BY HASH (c2) SUBPARTITIONS 2( PARTITION p1, PARTITION p2);DROP TABLE t_hash_hash;-- list-listCREATE TABLE list_list( month_code VARCHAR2 ( 30 ) NOT NULL , dept_code VARCHAR2 ( 30 ) NOT NULL , user_no VARCHAR2 ( 30 ) NOT NULL , sales_amt int)PARTITION BY LIST (month_code) SUBPARTITION BY LIST (dept_code, user_no)( PARTITION p_201901 VALUES ( '201902' ), PARTITION p_201902 VALUES ( '201903' ) ( SUBPARTITION p_201902_a VALUES (('1','120')), SUBPARTITION p_201902_b VALUES (('2','240')) ));SELECT * FROM pg_get_tabledef('list_list');INSERT INTO list_list VALUES('201902', '1', '120', 1);INSERT INTO list_list VALUES('201902', '2', '240', 1);INSERT INTO list_list VALUES('201902', '1', '120', 1);INSERT INTO list_list VALUES('201903', '2', '240', 1);INSERT INTO list_list VALUES('201903', '1', '120', 1);INSERT INTO list_list VALUES('201903', '2', '240', 1);SELECT * FROM list_list ORDER BY month_code;DROP TABLE list_list;-- hash-rangeCREATE TABLE hash_range( month_code VARCHAR2 ( 30 ) NOT NULL , dept_code VARCHAR2 ( 30 ) NOT NULL , user_no VARCHAR2 ( 30 ) NOT NULL , sales_amt int)PARTITION BY hash (month_code) SUBPARTITION BY range (dept_code,user_no)( PARTITION p_201901, PARTITION p_201902 ( SUBPARTITION p_201902_a VALUES LESS THAN ( '2' ,'2'), SUBPARTITION p_201902_b VALUES LESS THAN ( '3' ,'4') ));INSERT INTO hash_range VALUES('201901', '1', '1', 1);INSERT INTO hash_range VALUES('201901', '2', '1', 1);INSERT INTO hash_range VALUES('201901', '1', '1', 1);INSERT INTO hash_range VALUES('201903', '2', '1', 1);INSERT INTO hash_range VALUES('201903', '1', '1', 1);INSERT INTO hash_range VALUES('201903', '2', '1', 1);SELECT * FROM hash_range;DROP TABLE hash_range;
![](https://support.huaweicloud.com/fg-gaussdb-cent-v8/public_sys-resources/caution_3.0-zh-cn.png)
Interval分区看成是范围分区的一种特殊形式,目前不支持二级分区场景中定义Interval分区。
父主题: 分区策略
support.huaweicloud.com/fg-gaussdb-cent-v8/gaussdb-48-0069.html
看了此文的人还看了
CDN加速
GaussDB
文字转换成语音
免费的服务器
如何创建网站
域名网站购买
私有云桌面
云主机哪个好
域名怎么备案
手机云电脑
SSL证书申请
云点播服务器
免费OCR是什么
电脑云桌面
域名备案怎么弄
语音转文字
文字图片识别
云桌面是什么
网址安全检测
网站建设搭建
国外CDN加速
SSL免费证书申请
短信批量发送
图片OCR识别
云数据库MySQL
个人域名购买
录音转文字
扫描图片识别文字
OCR图片识别
行驶证识别
虚拟电话号码
电话呼叫中心软件
怎么制作一个网站
Email注册网站
华为VNC
图像文字识别
企业网站制作
个人网站搭建
华为云计算
免费租用云托管
云桌面云服务器
ocr文字识别免费版
HTTPS证书申请
图片文字识别转换
国外域名注册商
使用免费虚拟主机
云电脑主机多少钱
鲲鹏云手机
短信验证码平台
OCR图片文字识别
SSL证书是什么
申请企业邮箱步骤
免费的企业用邮箱
云免流搭建教程
域名价格
推荐文章