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

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

  • 环境介绍
  • [1 按 年 - 间隔分区表](#1 按 年 - 间隔分区表)
  • [2 按 月 - 间隔分区](#2 按 月 - 间隔分区)
  • [3 按 日 - 间隔分区](#3 按 日 - 间隔分区)
  • [4 按 数值 - 间隔分区表](#4 按 数值 - 间隔分区表)
  • [5 达梦数据库学习使用列表](#5 达梦数据库学习使用列表)

环境介绍

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

1 按 年 - 间隔分区表

sql 复制代码
--间隔分区-- 时间间隔函数
-- 年,月 转换一个指定的 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 按 月 - 间隔分区

sql 复制代码
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 按 日 - 间隔分区

sql 复制代码
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 按 数值 - 间隔分区表

sql 复制代码
--间隔分区表--数值间隔
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 达梦数据库学习使用列表

相关推荐
PyAIGCMaster8 分钟前
文本模式下成功。ubuntu P104成功。
服务器·数据库·ubuntu
drebander21 分钟前
MySQL 查询优化案例分享
数据库·mysql
初晴~36 分钟前
【Redis分布式锁】高并发场景下秒杀业务的实现思路(集群模式)
java·数据库·redis·分布式·后端·spring·
盖世英雄酱5813642 分钟前
InnoDB 的页分裂和页合并
数据库·后端
YashanDB2 小时前
【YashanDB知识库】XMLAGG方法的兼容
数据库·yashandb·崖山数据库
独行soc2 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍11基于XML的SQL注入(XML-Based SQL Injection)
数据库·安全·web安全·漏洞挖掘·sql注入·hw·xml注入
风间琉璃""3 小时前
bugkctf 渗透测试1超详细版
数据库·web安全·网络安全·渗透测试·内网·安全工具
drebander4 小时前
SQL 实战-巧用 CASE WHEN 实现条件分组与统计
大数据·数据库·sql
IvorySQL4 小时前
IvorySQL 4.0 发布:全面支持 PostgreSQL 17
数据库·postgresql·开源数据库·国产数据库·ivorysql
18号房客4 小时前
高级sql技巧进阶教程
大数据·数据库·数据仓库·sql·mysql·时序数据库·数据库架构