openGauss学习笔记-72 openGauss 数据库管理-创建和管理分区表

news/2024/7/23 16:06:03

文章目录

    • openGauss学习笔记-72 openGauss 数据库管理-创建和管理分区表
      • 72.1 背景信息
      • 72.2 操作步骤
        • 72.2.1 使用默认表空间
          • 72.2.1.1 创建分区表(假设用户已创建tpcds schema)
          • 72.2.1.2 插入数据
          • 72.2.1.3 修改分区表行迁移属性
          • 72.2.1.4 删除分区
          • 72.2.1.5 增加分区
          • 72.2.1.6 重命名分区
          • 72.2.1.7 查询分区
          • 72.2.1.8 删除分区表和表空间
        • 72.2.2 使用用户自定义表空间
          • 72.2.2.1 创建表空间
          • 72.2.2.2 创建分区表
          • 72.2.2.3 插入数据
          • 72.2.2.4 修改分区表行迁移属性
          • 72.2.2.5 删除分区
          • 72.2.2.6 增加分区
          • 72.2.2.7 重命名分区
          • 72.2.2.8 修改分区的表空间
          • 72.2.2.9 查询分区
          • 72.2.2.10 删除分区表和表空间

openGauss学习笔记-72 openGauss 数据库管理-创建和管理分区表

72.1 背景信息

openGauss数据库支持的分区表为范围分区表、列表分区表、哈希分区表。

  • 范围分区表:将数据基于范围映射到每一个分区,这个范围是由创建分区表时指定的分区键决定的。这种分区方式是最为常用的,并且分区键经常采用日期,例如将销售数据按照月份进行分区。
  • 列表分区表:将数据中包含的键值分别存储在不同的分区中,依次将数据映射到每一个分区,分区中包含的键值由创建分区表时指定。
  • 哈希分区表:将数据根据内部哈希算法依次映射到每一个分区中,包含的分区个数由创建分区表时指定。

分区表和普通表相比具有以下优点:

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

普通表若要转成分区表,需要新建分区表,然后把普通表中的数据导入到新建的分区表中。因此在初始设计表时,请根据业务提前规划是否使用分区表。

72.2 操作步骤

72.2.1 使用默认表空间

72.2.1.1 创建分区表(假设用户已创建tpcds schema)
postgres=# CREATE TABLE tpcds.customer_address
(ca_address_sk       integer                  NOT NULL   ,ca_address_id       character(16)            NOT NULL   ,ca_street_number    character(10)                       ,ca_street_name      character varying(60)               ,ca_street_type      character(15)                       ,ca_suite_number     character(10)                       ,ca_city             character varying(60)               ,ca_county           character varying(30)               ,ca_state            character(2)                        ,ca_zip              character(10)                       ,ca_country           character varying(20)               ,ca_gmt_offset       numeric(5,2)                        ,ca_location_type    character(20)
)
PARTITION BY RANGE (ca_address_sk)
(PARTITION P1 VALUES LESS THAN(5000),PARTITION P2 VALUES LESS THAN(10000),PARTITION P3 VALUES LESS THAN(15000),PARTITION P4 VALUES LESS THAN(20000),PARTITION P5 VALUES LESS THAN(25000),PARTITION P6 VALUES LESS THAN(30000),PARTITION P7 VALUES LESS THAN(40000),PARTITION P8 VALUES LESS THAN(MAXVALUE)
)
ENABLE ROW MOVEMENT;

当结果显示为如下信息,则表示创建成功。

CREATE TABLE

img 说明: 创建列存分区表的数量建议不超过1000个。

72.2.1.2 插入数据

将表tpcds.customer_address的数据插入到表tpcds.web_returns_p2中。

例如在数据库中创建了一个表tpcds.customer_address的备份表tpcds.web_returns_p2,现在需要将表tpcds.customer_address中的数据插入到表tpcds.web_returns_p2中,则可以执行如下命令。

postgres=# CREATE TABLE tpcds.web_returns_p2
(ca_address_sk       integer                  NOT NULL   ,ca_address_id       character(16)            NOT NULL   ,ca_street_number    character(10)                       ,ca_street_name      character varying(60)               ,ca_street_type      character(15)                       ,ca_suite_number     character(10)                       ,ca_city             character varying(60)               ,ca_county           character varying(30)               ,ca_state            character(2)                        ,ca_zip              character(10)                       ,ca_country           character varying(20)               ,ca_gmt_offset       numeric(5,2)                        ,ca_location_type    character(20)
)
PARTITION BY RANGE (ca_address_sk)
(PARTITION P1 VALUES LESS THAN(5000),PARTITION P2 VALUES LESS THAN(10000),PARTITION P3 VALUES LESS THAN(15000),PARTITION P4 VALUES LESS THAN(20000),PARTITION P5 VALUES LESS THAN(25000),PARTITION P6 VALUES LESS THAN(30000),PARTITION P7 VALUES LESS THAN(40000),PARTITION P8 VALUES LESS THAN(MAXVALUE)
)
ENABLE ROW MOVEMENT;
CREATE TABLE
postgres=# INSERT INTO tpcds.web_returns_p2 SELECT * FROM tpcds.customer_address;
INSERT 0 0
72.2.1.3 修改分区表行迁移属性
postgres=# ALTER TABLE tpcds.web_returns_p2 DISABLE ROW MOVEMENT;
ALTER TABLE
72.2.1.4 删除分区

删除分区P8。

postgres=# ALTER TABLE tpcds.web_returns_p2 DROP PARTITION P8;
ALTER TABLE
72.2.1.5 增加分区

增加分区P8,范围为 40000<= P8<=MAXVALUE。

postgres=# ALTER TABLE tpcds.web_returns_p2 ADD PARTITION P8 VALUES LESS THAN (MAXVALUE);
ALTER TABLE
72.2.1.6 重命名分区
  • 重命名分区P8为P_9。

    postgres=# ALTER TABLE tpcds.web_returns_p2 RENAME PARTITION P8 TO P_9;
    ALTER TABLE
    
  • 重命名分区P_9为P8。

    postgres=# ALTER TABLE tpcds.web_returns_p2 RENAME PARTITION FOR (40000) TO P8;
    ALTER TABLE
    
72.2.1.7 查询分区

查询分区P6。

postgres=# SELECT * FROM tpcds.web_returns_p2 PARTITION (P6);
postgres=# SELECT * FROM tpcds.web_returns_p2 PARTITION FOR (35888);
72.2.1.8 删除分区表和表空间
postgres=# DROP TABLE tpcds.customer_address;
DROP TABLE
postgres=# DROP TABLE tpcds.web_returns_p2;
DROP TABLE

72.2.2 使用用户自定义表空间

按照以下方式对范围分区表的进行操作。

72.2.2.1 创建表空间
openGauss=# CREATE TABLESPACE example1 RELATIVE LOCATION 'tablespace1/tablespace_1';
openGauss=# CREATE TABLESPACE example2 RELATIVE LOCATION 'tablespace2/tablespace_2';
openGauss=# CREATE TABLESPACE example3 RELATIVE LOCATION 'tablespace3/tablespace_3';
openGauss=# CREATE TABLESPACE example4 RELATIVE LOCATION 'tablespace4/tablespace_4';

当结果显示为如下信息,则表示创建成功。

CREATE TABLESPACE
72.2.2.2 创建分区表
openGauss=# CREATE TABLE tpcds.customer_address
(ca_address_sk       integer                  NOT NULL   ,ca_address_id       character(16)            NOT NULL   ,ca_street_number    character(10)                       ,ca_street_name      character varying(60)               ,ca_street_type      character(15)                       ,ca_suite_number     character(10)                       ,ca_city             character varying(60)               ,ca_county           character varying(30)               ,ca_state            character(2)                        ,ca_zip              character(10)                       ,ca_country           character varying(20)               ,ca_gmt_offset       numeric(5,2)                        ,ca_location_type    character(20)
)
TABLESPACE example1PARTITION BY RANGE (ca_address_sk)
(PARTITION P1 VALUES LESS THAN(5000),PARTITION P2 VALUES LESS THAN(10000),PARTITION P3 VALUES LESS THAN(15000),PARTITION P4 VALUES LESS THAN(20000),PARTITION P5 VALUES LESS THAN(25000),PARTITION P6 VALUES LESS THAN(30000),PARTITION P7 VALUES LESS THAN(40000),PARTITION P8 VALUES LESS THAN(MAXVALUE) TABLESPACE example2
)
ENABLE ROW MOVEMENT;

当结果显示为如下信息,则表示创建成功。

CREATE TABLE

img 说明: 创建列存分区表的数量建议不超过1000个。

72.2.2.3 插入数据

将表tpcds.customer_address的数据插入到表tpcds.web_returns_p2中。

例如在数据库中创建了一个表tpcds.customer_address的备份表tpcds.web_returns_p2,现在需要将表tpcds.customer_address中的数据插入到表tpcds.web_returns_p2中,则可以执行如下命令。

openGauss=# CREATE TABLE tpcds.web_returns_p2
(ca_address_sk       integer                  NOT NULL   ,ca_address_id       character(16)            NOT NULL   ,ca_street_number    character(10)                       ,ca_street_name      character varying(60)               ,ca_street_type      character(15)                       ,ca_suite_number     character(10)                       ,ca_city             character varying(60)               ,ca_county           character varying(30)               ,ca_state            character(2)                        ,ca_zip              character(10)                       ,ca_country           character varying(20)               ,ca_gmt_offset       numeric(5,2)                        ,ca_location_type    character(20)
)
TABLESPACE example1
PARTITION BY RANGE (ca_address_sk)
(PARTITION P1 VALUES LESS THAN(5000),PARTITION P2 VALUES LESS THAN(10000),PARTITION P3 VALUES LESS THAN(15000),PARTITION P4 VALUES LESS THAN(20000),PARTITION P5 VALUES LESS THAN(25000),PARTITION P6 VALUES LESS THAN(30000),PARTITION P7 VALUES LESS THAN(40000),PARTITION P8 VALUES LESS THAN(MAXVALUE) TABLESPACE example2
)
ENABLE ROW MOVEMENT;
CREATE TABLE
openGauss=# INSERT INTO tpcds.web_returns_p2 SELECT * FROM tpcds.customer_address;
INSERT 0 0
72.2.2.4 修改分区表行迁移属性
openGauss=# ALTER TABLE tpcds.web_returns_p2 DISABLE ROW MOVEMENT;
ALTER TABLE
72.2.2.5 删除分区

删除分区P8。

openGauss=# ALTER TABLE tpcds.web_returns_p2 DROP PARTITION P8;
ALTER TABLE
72.2.2.6 增加分区

增加分区P8,范围为 40000<= P8<=MAXVALUE。

openGauss=# ALTER TABLE tpcds.web_returns_p2 ADD PARTITION P8 VALUES LESS THAN (MAXVALUE);
ALTER TABLE
72.2.2.7 重命名分区
  • 重命名分区P8为P_9。

    openGauss=# ALTER TABLE tpcds.web_returns_p2 RENAME PARTITION P8 TO P_9;
    ALTER TABLE
    
  • 重命名分区P_9为P8。

    openGauss=# ALTER TABLE tpcds.web_returns_p2 RENAME PARTITION FOR (40000) TO P8;
    ALTER TABLE
    
72.2.2.8 修改分区的表空间
  • 修改分区P6的表空间为example3。

    openGauss=# ALTER TABLE tpcds.web_returns_p2 MOVE PARTITION P6 TABLESPACE example3;
    ALTER TABLE
    
  • 修改分区P4的表空间为example4。

    openGauss=# ALTER TABLE tpcds.web_returns_p2 MOVE PARTITION P4 TABLESPACE example4;
    ALTER TABLE
    
72.2.2.9 查询分区

查询分区P6。

openGauss=# SELECT * FROM tpcds.web_returns_p2 PARTITION (P6);
openGauss=# SELECT * FROM tpcds.web_returns_p2 PARTITION FOR (35888);
72.2.2.10 删除分区表和表空间
openGauss=# DROP TABLE tpcds.web_returns_p2;
DROP TABLE
openGauss=# DROP TABLESPACE example1;
openGauss=# DROP TABLESPACE example2;
openGauss=# DROP TABLESPACE example3;
openGauss=# DROP TABLESPACE example4;
DROP TABLESPACE

👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!

图片


https://dhexx.cn/news/show-5071413.html

相关文章

Python--测试代码

目录 1、使用pip安装pytest 1.1 更新pip 1.2 安装putest 2、测试函数 2.1 单元测试和测试用例 2.2 可通过的测试 2.3 运行测试 2.4 未通过的测试 2.5 解决测试未通过 2.6 添加新测试 3、测试类 3.1 各种断言 3.2 一个测试的类 3.3 测试AnonymousSurvey类 3.4 使…

RHCSA 重定向、vim练习题

1.重定向练习题 (1)新建一个文件redirect.txt&#xff0c;并在其中写入20210804RHCSA,保存并退出 先输入命令 [rootlocalhost ~]# vim redirect.txt进入vim编辑器后&#xff0c;按快捷键“i”进入编辑模式&#xff0c;再写入数据&#xff0c;写完之后按“esc"键退出编辑…

【多线程案例】定时器

1. 定时器是什么&#xff1f; 定时器也是软件开发中的一个重要组件. 类似于一个 "闹钟". 达到一个设定的时间之后, 就执行某个指定好的代码. 定时器是一种实际开发中非常常用的组件. 比如网络通信中, 如果对方 500ms 内没有返回数据, 则断开连接尝试重连. 比如一个 …

Day43:VUEX

1. 基本介绍 这里介绍的VueX是匹配Vue3的V4版本&#xff0c;它绝大多数功能使用都和之前基本保持一致。 1.1 官方定义 先一起看一下官网对于VueX的定义&#xff1a; Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 库。它采用集中式存储管理应用的所有组件的状态&…

各种数据库分页查询SQL

一、DB2: DB2分页查询 SELECT * FROM (Select 字段1,字段2,字段3,rownumber() over(ORDER BY 排序用的列名 ASC) AS rn from 表名) AS a1 WHERE a1.rn BETWEEN 10 AND 20 以上表示提取第10到20的纪录 select * from (select rownumber() over(order by id asc ) as rowid from …

负载均衡原理及应用

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

Leetcode168. Excel表列名称

力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 题解&#xff1a; 力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 代码如下&#xff1a; class Solution {public String convertToTitle(int columnNumber) {StringBuild…

Shell脚本编写:从零到精通

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

《动手学深度学习 Pytorch版》 5.6 GPU

5.6.1 计算设备 import torch from torch import nntorch.device(cpu), torch.device(cuda:0) # cuda等价于cuda:0&#xff08;只有一块显卡没法试别的块号&#xff09;(device(typecpu), device(typecuda, index0))torch.cuda.device_count() # 查询可用GPU数量1def try_gp…

Python实现四维图像绘制系统

文章目录 动图绘制系统的实现播放控制接口优化总结 Python绘图系统&#xff1a; &#x1f4c8;从0开始的3D绘图系统&#x1f4c9;一套3D坐标&#xff0c;多个函数&#x1f4ca;散点图、极坐标和子图自定义控件&#xff1a;绘图风格&#x1f4c9;风格控件&#x1f4ca;定制绘图…