间隔分区表(DM8:达梦数据库)

环境介绍

  • 间隔分区表使用说明:
    1. 仅支持一级范围分区创建间隔分区。
    1. 只能有一个分区列,且分区列类型为日期或数值。
    1. 对间隔分区进行 SPLIT,只能在间隔范围内进行操作。
    1. 被 SPLIT/MERGE 的分区,其左侧分区不再进行自动创建。
    1. 不相邻的间隔的分区,不能 MERGE。
    1. 表定义不能包含 MAXVALUE 分区。
    1. 不允许新增分区。
    1. 不能删除起始间隔分区。
    1. 间隔分区表定义语句显示到起始间隔分区为止。
    1. 自动生成的间隔分区,均不包含边界值。
    1. MPP 下不支持间隔分区表。

1 按 年 - 间隔分区表

--间隔分区-- 时间间隔函数
-- 年,月 转换一个指定的 DEC 类型值到 INTERVAL YEAR TO MONTH
SELECT NUMTOYMINTERVAL(N,INTERVAL_UNIT);
SELECT SYSDATE+NUMTOYMINTERVAL(1,'YEAR');--按年 间隔分区

CREATE TABLE TYEAR(ID INT,NAME VARCHAR(20),BIR DATE)
PARTITION BY RANGE(BIR) 
	INTERVAL(NUMTOYMINTERVAL(1,'YEAR'))(
	PARTITION P1990 VALUES LESS THAN (TO_DATE('1991-01-01','YYYY-MM-DD')),
	PARTITION P1991 VALUES LESS THAN (TO_DATE('1992-01-01','YYYY-MM-DD')));
	
	INSERT INTO TYEAR VALUES(1,'AAAAA','1990-03-01');
	COMMIT;	--存入P1990分区表中
	INSERT INTO TYEAR VALUES(2,'BBBBB','1995-03-01');
	COMMIT;  --存入自动新建分区表中

2 按 月 - 间隔分区

SELECT SYSDATE+NUMTOYMINTERVAL(1,'MONTH');--按月 间隔分区
CREATE TABLE TMONTH(ID INT,NAME VARCHAR(20),BIR DATE)
PARTITION BY RANGE(BIR) 
	INTERVAL(NUMTOYMINTERVAL(1,'MONTH'))(
	PARTITION P9101 VALUES LESS THAN (TO_DATE('1991-02-01','YYYY-MM-DD')),
	PARTITION P9102 VALUES LESS THAN (TO_DATE('1991-03-01','YYYY-MM-DD')));
	
	INSERT INTO TMONTH VALUES(1,'AAAAA','1991-01-01');
	COMMIT;	--存入P9101分区表中
	INSERT INTO TMONTH VALUES(2,'BBBBB','1991-05-01');
	COMMIT;  --存入自动新建分区表中

3 按 日 - 间隔分区


SELECT NUMTODSINTERVAL(N,INTERVAL_UNIT);
SELECT SYSDATE+NUMTODSINTERVAL(1,'DAY'); --按 日 间隔分区
-- 日 转换一个指定的 DEC 类型到 INTERVAL DAY TO SECOND
SELECT NUMTODSINTERVAL(N,INTERVAL_UNIT);
SELECT SYSDATE+NUMTODSINTERVAL(1,'DAY');

CREATE TABLE TDAY(ID INT,NAME VARCHAR(20),BIR TIMESTAMP)
PARTITION BY RANGE(BIR) 
	INTERVAL(NUMTODSINTERVAL(1,'DAY'))(
	PARTITION P910101 VALUES LESS THAN (TO_DATE('1991-01-02 00:00:00','YYYY-MM-DD HH24:MI:SS')),
	PARTITION P910102 VALUES LESS THAN (TO_DATE('1991-01-03 00:00:00','YYYY-MM-DD HH24:MI:SS')));
	
	INSERT INTO TDAY VALUES(1,'AAAAA','1991-01-01 00:00:00');
	COMMIT;	--存入P910101分区表中
	INSERT INTO TDAY VALUES(2,'BBBBB','1991-01-05 00:00:00');
	COMMIT;  --存入自动新建分区表中

4 按 数值 - 间隔分区表

--间隔分区表--数值间隔
CREATE TABLE T_R11
(EMPLOYEE_ID INT,
EMPLOYEE_NAME VARCHAR(20),
BIR DATETIME)
PARTITION BY RANGE(EMPLOYEE_ID)
INTERVAL(10)
(PARTITION P1990 VALUES LESS THAN(10));

insert into SYSDBA.T_R11 VALUES(9,'AAA','1990-01-01');
COMMIT;  --存入P1990分区表中
insert into SYSDBA.T_R11 VALUES(10,'AAA','1990-01-01');
COMMIT;	--存入自动新建的分区表中
insert into SYSDBA.T_R11 VALUES(20,'AAA','1990-01-01');
COMMIT;	--存入再次新建的分区表中

5 达梦数据库学习使用列表

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
数据库可以通过以下步骤为建立分区: 1. 创建分区空间(Partitioned Tablespace) 使用以下语句创建分区空间: ``` CREATE TABLESPACE partition_tablespace DATAFILE 'path_to_datafile' SIZE 10G EXTENT MANAGEMENT LOCAL UNIFORM SIZE 64M; ``` 其中,partition_tablespace为分区空间名称,path_to_datafile为数据文件路径,SIZE指定空间大小,EXTENT MANAGEMENT指定分区管理方式,LOCAL示本地管理,UNIFORM SIZE指定分区大小。 2. 创建分区(Partitioned Table) 使用以下语句创建分区: ``` CREATE TABLE partition_table ( id NUMBER, name VARCHAR2(50), date_of_birth DATE ) PARTITION BY RANGE (date_of_birth) ( PARTITION p1 VALUES LESS THAN (TO_DATE('01-01-2000', 'DD-MM-YYYY')), PARTITION p2 VALUES LESS THAN (TO_DATE('01-01-2010', 'DD-MM-YYYY')), PARTITION p3 VALUES LESS THAN (MAXVALUE) ) TABLESPACE partition_tablespace; ``` 其中,partition_table为名,id、name、date_of_birth为字段,PARTITION BY指定分区方式,RANGE示按照范围分区,date_of_birth为分区字段,p1、p2、p3为分区名称,VALUES LESS THAN指定分区的值范围,MAXVALUE分区的最大值,TABLESPACE指定所使用的空间。 3. 插入数据 使用INSERT语句向分区中插入数据即可。 注意:在创建分区时,必须指定所使用的分区空间。同时,分区分区键必须是中的某一列,且该列必须具有可以进行比较的数据类型。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值