mysql分区表的增删改查操作

news2025/2/21 20:57:19

mysql分区表的增删改查操作

  • 一、mysql创建表分区
  • 二、基本分区信息查询
    • 2.1 查看mysql版本是否支持分区
    • 2.2 查看表是否为分区表
      • 2.2.1 查询表分区信息
      • 2.2.2 查看表的所有分区
  • 三、分区表的查询操作
  • 四、分区表的增删改操作
    • 4.1 新增分区
      • 4.1.1 给已有的表加上分区
      • 4.1.2 新增分区
    • 4.2 重新分区
    • 4.3 删除
      • 4.3.1 删除表
      • 4.3.2 删除分区
      • 4.3.4 删除指定分区中的数据
    • 4.4 数据插入
      • 4.4.1 按表插入
      • 4.4.2 按分区插入
      • 4.4.2 按分区批量插入

一、mysql创建表分区

详情参考链接:mysql创建表分区详细介绍及示例

二、基本分区信息查询

官方链接 : mysql分区的相关增删改查操作

2.1 查看mysql版本是否支持分区

mysql> show plugins

即:看名为partition的插件是否为active,active表示支持分区。
1
并且同一个数据库,不同表支持分区可以是不同的存储引擎,但是表分区后所有的分区都必须和表使用相同引擎。

MyISAM和InnoDB都支持分区。
MySQL 8都无需插件即可支持分区,且只有InnoDB支持,MyISAM不支持分区。
MySQL 5.7 的NDB支持分区有自己的规则。
MySQL只支持水平分区,对垂直分区的支持无计划。

2.2 查看表是否为分区表

2.2.1 查询表分区信息

  1. 查看创建分区表的create语句show create table 表名;

示例:show create table dev_fac;
3

  1. 查看表是不是分区表:show table status;

示例:show table status;
4

2.2.2 查看表的所有分区

  查看对应数据库、对应表的所有分区信息

SELECT
	partition_name part,
	partition_expression expr,
	partition_description descr,
	table_rows
FROM
	INFORMATION_SCHEMA. PARTITIONS
WHERE
	TABLE_SCHEMA = "库名称"
AND TABLE_NAME = "表名称";

示例:

SELECT
	partition_name part,
	partition_expression expr,
	partition_description descr,
	table_rows
FROM
	INFORMATION_SCHEMA. PARTITIONS
WHERE
	TABLE_SCHEMA = "test"
AND TABLE_NAME = "dev_fac";

结果如下:
2

三、分区表的查询操作

MySQL 5.7支持显式选择分区和子分区,在执行语句时,应检查是否有与给定WHERE条件匹配的行。分区选择与分区精简相似,分区选择只检查特定分区的匹配情况,但在两个关键方面有所不同:

  1. 分区选择要检查的分区由语句的发布者指定,而分区精简它是自动的。
  2. 尽管分区精简仅适用于查询,但查询和许多DML语句都支持分区的显式选择。
  3. 支持显式分区选择的SQL语句如下:
SELECT * FROM 表名  PARTITION (分区名称1,分区名称2,分区名称n) WHERE 查询条件;

示例:3

  1. 隐式分区要注意where条件中需要包含分区的关键字,以确保查询时是通过分区查询,而不是全表扫描,查询语句如下:
SELECT * FROM 表名  WHERE 查询条件;

显示扫描哪些分区,及它们是如何使用的:
  在查询语句前面加上EXPLAIN PARTITIONS 关键字.

示例: EXPLAIN PARTITIONS SELECT * FROM dev_date WHERE Partition_Date = ‘2022-11-25 16:07:00’;
1

四、分区表的增删改操作

4.1 新增分区

4.1.1 给已有的表加上分区

alter table 表名 partition by 分区逻辑;

示例:

alter table results partition by RANGE (month(ttime)) (
PARTITION p5 VALUES LESS THAN (6) , 
PARTITION p11 VALUES LESS THAN (12),
PARTITION P12 VALUES LESS THAN MAXVALUE
);

4.1.2 新增分区

  新增分区需要先确认表为分区表。

alter table 表名 add partition (partition 分区名称 values less than (逻辑));

1. range添加新分区

mysql> alter table user add partition(partition p4 values less than MAXVALUE);

2. list添加新分区

mysql> alter table list_part add partition(partition p4 values in (25,26,28));

3. hash重新分区

mysql> alter table hash_part add partition partitions 4;

4.key重新分区

mysql> alter table key_part add partition partitions 4;

4.2 重新分区

1. range重新分区

mysql> ALTER TABLE user REORGANIZE PARTITION p0,p1,p2,p3,p4 INTO (PARTITION p0 VALUES LESS THAN MAXVALUE);

2. list重新分区

mysql> ALTER TABLE list_part REORGANIZE PARTITION p0,p1,p2,p3,p4 INTO (PARTITION p0 VALUES in (1,2,3,4,5));

3. hash和key分区不能用REORGANIZE,官方网站说的很清楚

mysql> ALTER TABLE key_part REORGANIZE PARTITION COALESCE PARTITION 9;

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘PARTITION 9’ at line 1

4.3 删除

4.3.1 删除表

  表删除,对应的分区及数据也会删除。

DROP TABLE 表名称`;

4.3.2 删除分区

alter table 表名  drop partition 分区名称;
-- 示例
alter table staff  drop partition p0;

  如果你使用例子给出的分区方案,你只需执行语句alter table staff drop partition p0来删除所有在1991年前就已经停止工作的雇员相对应的所有行。对于有大量行的表,这比运行一个如”delete from staff WHERE year(separated) <= 1990;”这样的一个DELETE查询要有效得多。

4.3.4 删除指定分区中的数据

DELETE
FROM
	表名  PARTITION  (分区名称1,分区名称2,分区名称n)
WHERE 子句

示例:DELETE FROM dev_fac PARTITION(p1000000000000001) WHERE devName = ‘D10000000000000011名称’
5

4.4 数据插入

4.4.1 按表插入

  直接按表插入,数据库自动根据数据查找分区插入。

INSERT INTO `dev_fac`
VALUES
	(
		'D10000000000000010',
		'D10000000000000010名称',
		'F1000000000000001',
		'2022-11-25 16:07:00',
		'1',
		'1669363620000',
		'1',
		'1000000000000001',
		'2022-11-25 16:07:00'
	);

4.4.2 按分区插入

  插入语句中指定插入的分区信息。

INSERT INTO 表名  PARTITION  (分区名称1,分区名称2,分区名称n)
列名  VALUES()

示例:
INSERT INTO dev_fac PARTITION (1000000000000001)
VALUES(
‘D10000000000000012’,
‘D10000000000000012名称’,
‘F1000000000000001’,
‘2022-11-25 16:07:00’,
‘1’,
‘1669363620000’,
‘1’,
‘1000000000000001’,
‘2022-11-25 16:07:00’
);

4.4.2 按分区批量插入

  插入语句中指定插入的分区信息且一次插入多条数据。

INSERT INTO 表名  PARTITION  (分区名称1,分区名称2,分区名称n)
列名  VALUES(),(),(),...,()

示例:

INSERT INTO `dev_fac` PARTITION (p1000000000000001)
VALUES(
		'D10000000000000012',
		'D10000000000000012名称',
		'F1000000000000001',
		'2022-11-25 16:07:00',
		'1',
		'1669363620000',
		'1',
		'1000000000000001',
		'2022-11-25 17:07:00'
	),
	(
		'D10000000000000013',
		'D10000000000000013名称',
		'F1000000000000001',
		'2022-11-25 16:07:00',
		'1',
		'1669363620000',
		'1',
		'1000000000000001',
		'2022-11-25 17:07:00'
	);

6

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/53249.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

面试字节,过关斩将到 3 面,结果找了个架构师来吊打我?

人人都有大厂梦&#xff0c;对于程序员来说&#xff0c;BAT 为首的一线互联网公司肯定是自己的心仪对象&#xff0c;毕竟能到这些大厂工作&#xff0c;不仅薪资高待遇好&#xff0c;而且能力技术都能够得到提升&#xff0c;最关键的是还能够给自己镀上一层金&#xff0c;让人瞻…

物联网卡与共享饮水机的关系

近些年来居民更加注重饮水健康&#xff0c;对水质&#xff0c;口感的要求明显提升&#xff0c;饮水机市场高速发展&#xff0c;很多小区&#xff0c;校园&#xff0c;公园等公共场所都出现了共享饮水机。共享饮水机随处可见&#xff0c;马路边、商场里、社区里的社区直饮水机等…

Java+JSP+MySQL基于SSM的扶贫信息管理系统-计算机毕业设计

项目介绍 扶贫信息管理系统采用了B/S(浏览器/服务器)体系结构&#xff0c;JAVA作为开发语言&#xff0c;MySQL作为数据存储进行开发&#xff0c;Tomcat作为WEB服务器&#xff0c;开发平台windows&#xff0c;开发工具采用比elicpse更好用的myeclipse。系统角色分为用户和管理员…

GIS工具maptalks开发手册(二)03——渲染面

GIS工具maptalks开发手册(二)03——渲染面 效果 1、html单页面 index.html <!DOCTYPE html> <html> <meta charset"UTF-8"> <meta name"viewport" content"widthdevice-width, initial-scale1"> <title>图形 -…

Linux基础知识与实操-篇三: 文件压缩打包与vim基本使用

文章目录压缩打包与备份压缩文件命令gzip bzip2 xzgzip 命令bzip2 命令xz命令打包指令XFS文件系统备份与还原光盘写入工具其他常见的压缩与备份工具Vim 基本使用多文件编辑多窗口编辑Vim 的关键字补全Vim环境设定与记录其他使用注意事项中文编码问题断行字符语系编码转换最后本…

Spring依赖注入的三种方式

参考 : 面试突击77&#xff1a;Spring 依赖注入有几种&#xff1f;各有什么优缺点&#xff1f; - 掘金 目录 更加简单地从Spring中取出Bean对象(超级重要) 属性注入 属性注入的优点和缺点 setter注入 Setter注入的优缺点 构造方法注入 注意事项 构造方法注入的优缺点 …

基于springboot书籍推荐系统设计与实现的源码+文档

DROP TABLE IF EXISTS book_classification; CREATE TABLE book_classification( book_classification_id int(11) NOT NULL AUTO_INCREMENT COMMENT 图书分类ID, book_category varchar(64) comment 图书类别, examine_state varchar(16) DEFAULT 已通过 NOT NULL comm…

01-go基础-06-切片(声明切片、初始化切片、切片赋值、切片长度、切片容量、空切片、append、copy)

文章目录1. 声明切片2. 初始化切片2.1 切片长度2.1.1 初始化指定长度的切片2.1.2 查看切片长度 len()2.2 切片容量2.2.1 初始化指定容量的切片2.2.2 查看切片长度 len()3 切片赋值3.1 直接赋值3.2 引用数组给切片赋值3.3 引用数组某区间给切片赋值3.3.1 从数组位置N个取到第M个…

k8s中的Pod

Pod 是可以在 Kubernetes 中创建和管理的、最小的可部署的计算单元; Pod 中会启动一个或一组紧密相关的业务容器, 各个业务容器相当于Pod 中的各个进程, 此时就可以将Pod 作为虚拟机看待; 在创建 Pod 时会启动一个init容器, 用来初始化存储和网络, 其余的业务容器都将在init容器…

redis在实践中的一些常见问题以及优化思路(包含linux内核参数优化)

文章目录redis在实践中的一些常见问题以及优化思路&#xff08;包含linux内核参数优化&#xff09;fork耗时导致高并发请求延时AOF的阻塞问题主从复制延迟问题主从复制风暴问题vm.overcommit_memoryswapiness最大打开文件句柄tcp backlogredis在实践中的一些常见问题以及优化思…

【数据库高级】Mysql窗口函数的使用和练习

Mysql窗口函数&#x1f33e;Mysql窗口函数&#x1f54a;️一、什么是窗口函数&#x1f343;1、怎么理解窗口?&#x1f343;2、什么是窗口函数&#x1f375;1. 基本语法&#xff1a;&#x1f375;2. 窗口函数多用在什么场景&#xff1f;主要有以下两类&#xff1a;&#x1f375…

【AAAI2023】视觉辅助的常识知识获取Visually Grounded Commonsense Knowledge Acquisition 个人学习笔记

视觉辅助的常识知识获取 摘要&#xff1a;大规模的常识知识库为广泛的AI应用提供了能力&#xff0c;其中常识知识的自动提取extraction of commonsense knowledge (CKE)是一个基本和具有挑战性的问题。文本中的CKE因其固有的稀疏性和文本中常识的报道偏差reporting bias而闻名…

Windows OpenGL ES 图像色调

目录 一.OpenGL ES 图像色调 1.原始图片2.效果演示 二.OpenGL ES 图像色调源码下载三.猜你喜欢 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 基础 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 特效 零基础 OpenGL E…

Java+JSP+MySQL基于SSM的在线投票系统-计算机毕业设计

项目介绍 随着社会的发展&#xff0c;人们在处理一些问题的时候不同意见越来越多&#xff0c;这源于人们对思想的解放和对社会的认识。所以在处理同一问题上&#xff0c;为了征求不同人的意见在线投票系统诞生了。 基于SSM的在线投票系统以钦州学院为背景&#xff0c;运用在校…

CSS详解

文章目录1. CSS快速入门2. 四种CSS导入方式3. 三种基本选择器4. 层次选择器5. 结构伪类选择器5. 属性选择器6. CSS样式HTML(结构)CSS(表现)JavaScript(交互)1. CSS快速入门 <style>可以编写css代码&#xff0c;每一个声明&#xff0c;最好使用分号; <!DOCTYPE html&…

【JavaWeb】Servlet系列 --- HttpServletRequest接口详解(接口方法要记住!!!)

HttpServletRequest接口一、HttpServletRequest接口中有哪些常用的方法&#xff1f;思考&#xff1a;如果是前端的form表单提交了数据之后&#xff0c;你准备怎么存储这些数据&#xff0c;你准备采用什么样的数据结构去存储这些数据呢&#xff1f;二、request接口中四个非常重要…

FlutterAcivity 包已导入 但是仍然爆红

FlutterAcivity 包已导入 但是仍然爆红 这种情况就比较广泛了 我说一下我遇到的这种情况 上一篇 FlutterActivity找不到http://t.csdn.cn/HvgtI 1.大家可以看到我这个FlutterActivity包已导入 但是依然报错 2.可以清楚的看到我这个提示是 LifecycleOwner 找不到我们点Flutter…

智慧工地安全施工实时监测系统解决方案

背景介绍 随着经济的发展&#xff0c;混凝土搅拌车数量有很大增长&#xff0c;但是其超速、超载等原因造成了很多交通事故&#xff0c;给交通安全带来隐患&#xff0c;也给企业造成损失&#xff0c;严重影响了和谐城市建设的进程。 中国电子科技集团第52研究所经过多年研发与…

React子组件没有随父组件更新问题的解决

前言&#xff1a;今天遇到一个小需求&#xff0c;本来只是修改文案的&#xff0c;结果问题卡了很久很久&#xff0c;想想还是太菜了 问题描述&#xff1a; 根据changePlaceHolder修改AInput的placeholder的默认值&#xff0c;AInput是封装的antd的input组件&#xff0c;期间发…

图片一键调整工具V1.0-免费版

一、工具介绍 这是博主自己开发的图片一键调整工具V1.0,它可以调整图片宽度和高度、压缩图片大小、改变图片背景、转换图片格式和图片透明化&#xff0c;都是很常用的功能。操作起来简单方便。 二、工具操作 1.调整图片背景 首先&#xff0c;把该工具软件和图片放到同一文件…