当前位置: 首页 > news >正文

sql分区

将学员表student按所在城市使用PARTITION BY LIST

1、创建分区表。

CREATE TABLE public.student( 
sno numeric(4,0),                
sname character varying(20 char),gender character varying(2 char),                
phone numeric(11,0),               id no character varying(18 char),                
city character varying(20 char),                
reg_date date,
job character varying(30 char),              
company character varying(30 char)            
)PARTITION BY LIST(city);

2、创建子分区。

 CREATE TABLE public.student_p1 PARTITION OF student FOR VALUES IN ('Beijing','shanghai');CREATE TABLE public.student_p2 PARTITION OF student FOR VALUES IN ('Tianjin','Guangzhou');CREATE TABLE public.student_p3 PARTITION OF student FOR VALUES IN ('chongging','chengdu');CREATE TABLE public.student default p PARTITION OF Student DEFAULT;

3、查看分区表。

 \d+ studentSELECT partitioning_type,partition_count FROM user_part_tables WHEREtable name ="STUDENT";

4、插入测试数据、执行数据查询、查看SQL执行计划。

 INSERT INTO public.student SELECT * FROM exam.student;EXPLAIN SELECT * FROM public.student;EXPLAIN SELECT * FROM public.student WHERE city='chongqing';

将学员表student按报名时间使用PARTITION BY RANGE


1、创建 student 分区表。

 CREATE TABLE public.student(sno numeric(4,0),sname character varying(20 char),gender character varying(2 char),phone numeric(11,0),id no character varying(18 char),city character varying(20 char),reg_date date,
job character varying(30 char),
company character varying(30 char)
)PARTITION BY RANGE(reg_date);

2、创建子分区。

 CREATE TABLE Student_p1 PARTITION OF Student FOR VALUES FROM ('2021-01-01') TO ('2021-03-31');CREATE TABLE Student_p2 PARTITION OF Student FOR VALUES FROM ('2021-04-01') TO ('2021-06-30');CREATE TABLE Student_p3 PARTITION OF Student FOR VALUES FROM ('2021-07-01') TO ('2021-09-30');CREATE TABLE Student_p4 PARTITION OF Student FOR VALUES FROM ('2021-10-01') TO ('2021-12-31');CREATE TABLE student_default_p PARTITION OF Student DEFAULT;

3、查看分区表。

\d+ student

4、插入测试数据、执行数据查询、查看SQL执行计划。

 INSERT INTO public.student SELECT * FROM exam.student;EXPLAIN SELECT * FROM public.student;EXPLAIN SELECT * FROM public.student WHERE reg_date between '2021-02-01'and '2021-02-28';

将学员表student按学员编号使用PARTITION BY HASH

1、创建分区表

CREATE TABLE public.student(
sno numeric(4,0),
sname character varying(20 char),
gender character varying(2 char),
phone numeric(11,0),
id no character varying(18 char),
city character varying(20 char),reg_date date,job character varying(30 char),
company character varying(30 char)
)PARTITION BY HASH(sno);

2、创建子分区。

CREATE TABLE Student_p1 PARTITION OF Student FOR VALUES WITH (MODULUS 4, REMAINDER 0);
CREATE TABLE Student_p2 PARTITION OF Student FOR VALUES WITH (MODULUS 4, REMAINDER 1);CREATE TABLE Student_p3 PARTITION OF Student FOR VALUES WITH (MODULUS 4, REMAINDER 2);CREATE TABLE Student_p4 PARTITION OF Student FOR VALUES WITH (MODULUS 4, REMAINDER 3);

3、查看分区表。

 \d+ student

4、插入测试数据、执行数据查询、查看SQL执行计划,

 INSERT INTO public.student SELECT * FROM exam.student;EXPLAIN SELECT * FROM public.student;EXPLAIN SELECT* FROM public.student where sno=5;

通过表继承和触发器创建分区表

1、创建父表

CREATE TABLE student(sid int,name text,reg_date date not null);

2、创建子表

 CREATE TABLE student_2019(CHECK(reg_date>='2019-01-01' and reg_date<'2020-01-01'))  INHERITS(student);
CREATE TABLE student_2020(CHECK(reg_date>='2020-01-01' and reg_date<'2021-01-01')) INHERITS(student);CREATE TABLE student_2021(CHECK(reg date>='2021-01-01' and reg_date<'2022-01-01'))  INHERITS(student);

3、创建触发器函数

CREATE OR REPLACE FUNCTION fun_students_insert()RETURNS TRIGGER AS $$BEGINIF(NEW.reg_date>='2019-01-01" AND NEW.reg_date<'2020-01-01')THEN INSERT INTO student_2019 VALUES(NEW.*);ELSIF (NEW.reg_date>='2020-01-01' AND NEW.reg_date<'2021-01-01')THEN INSERT INTO studen_2020 VALUES (NEW.*);ELSE
tests#        INSERT INTO student_2021 VALUES(NEW.*);END IF:
tests#  RETURN NULL;END;$$LANGUAGE pIsql;\df fun_students_insert

4、创建触发器

 CREATE TRIGGER tri_students_insertBEFORE INSERT ON studentFOR EACH ROW EXECUTE PROCEDURE fun_students_insert();

5、插入测试数据

 INSERT INTO student VALUES( 1001, 'LiMing','2019-01-03');INSERT INTO student VALUES( 1002,'ZhaoHai','2020-05-13');INSERT INTO student VALUES( 1001,'SunQian','2021-09-20');INSERT INTO student VALUES( 1001,'LuXun','2020-4-08');INSERT INTO student VALUES( 1001,'SunWuKong','2021-8-02');

6、查询测试

 EXPLAIN SELECT * FROM student;EXPLAIN SELECT * FROM student WHERE reg_date >'2021-01-01';

http://www.lryc.cn/news/481502.html

相关文章:

  • [OpenGL]使用OpenGL实现硬阴影效果
  • 嵌入式采集网关(golang版本)
  • ctfshow(328)--XSS漏洞--存储型XSS
  • 【C#】Thread.CurrentThread的用法
  • 简单分享一下淘宝商品数据自动化抓取的技术实现与挑战
  • Netty篇(入门编程)
  • 【渗透测试】payload记录
  • 2024自动驾驶线控底盘行业研究报告
  • css3D变换用法
  • Rust:启动与关闭线程
  • Ubuntu 的 ROS 2 操作系统安装与测试
  • 在双显示器环境中利用Sunshine与Moonlight实现游戏串流的同时与电脑其他任务互不干扰
  • ElasticSearch备考 -- Cross cluster replication(CCR)
  • windows C#-异常处理
  • 边缘计算在智能制造中的应用
  • 点云开发:从入门到精通的全面教程
  • 【含文档】基于ssm+jsp的商店会员系统(含源码+数据库+lw)
  • 【大数据学习 | kafka高级部分】文件清除原理
  • dolphin 配置data 从文件导入hive 实践(一)
  • Docker Compose部署Rabbitmq(脚本下载延迟插件)
  • 麦当劳自助点餐机——实现
  • C++ STL CookBook 6:STL Containers (I)
  • 行转列实现方式总结
  • 【go从零单排】初探goroutine
  • HarmonyOS NEXT应用元服务开发Intents Kit(意图框架服务)本地搜索接入方案
  • C语言可变参数列表编程实战指南:从基础概念到高级应用的全面解析
  • AndroidStudio-文本显示
  • HBuilderX运行微信小程序,编译的文件在哪,怎么运行
  • 百亿AI数字人社会初现:Project Sid展示智能代理文明进化路径
  • 代码随想录训练营Day21 | 491.递增子序列 - 46.全排列 - 47.全排列 II - 332.重新安排行程 - 51.N皇后 - 37.解数独