mysql实现分区

文章目录

一、根据时间创建分区

  1. 创建时间分区表

    java 复制代码
    CREATE TABLE `table_time`  (
      `ID` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
      `STA_ID` int(11) NULL DEFAULT NULL COMMENT '业务ID',
      `STA_NAME` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '业务名称',
      `MONITOR_TIME` datetime(0) NOT NULL   COMMENT '监测时间',
      PRIMARY KEY (`ID`,`MONITOR_TIME`) USING BTREE
    ) ENGINE = InnoDB AUTO_INCREMENT = 2111262 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '测试表' ROW_FORMAT = Dynamic
    partition by range (to_days(MONITOR_TIME)) (
     	PARTITION p0 VALUES LESS THAN (TO_DAYS('2023-05-01')),
        PARTITION p1 VALUES LESS THAN (TO_DAYS('2023-06-01')) 	
        );
  2. 查看分区是否生效

    java 复制代码
    select partition_name part, partition_expression expr, partition_description descr, table_rows
     from  INFORMATION_SCHEMA.partitions  where TABLE_SCHEMA="库名" AND TABLE_NAME="表名";
  3. 时间格式化

    ps:由于我们是以时间作为分区,时间会被转成特殊的数字,所以如果想要查看分区属于哪个时间,还需要格式化下时间数据才可以查看

    java 复制代码
     SELECT DATE_SUB(DATE_ADD('0000-01-01', INTERVAL 740543 DAY), INTERVAL 1 DAY);

二、根据业务主键id创建分区

  1. 创建业务主键分区表

    java 复制代码
    CREATE TABLE `table_id`  (
      `id` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '主键  字符串',
      `car_id` int(11) NOT NULL  COMMENT '车辆ID',
      `car_no` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '车牌号'
    ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '车辆行驶轨迹' ROW_FORMAT = Dynamic
    PARTITION BY LIST COLUMNS(car_id)
    (PARTITION p0 VALUES IN (0) ENGINE = InnoDB);
  2. 根据业务主键添加分区

    java 复制代码
    ALTER TABLE table_id ADD PARTITION (PARTITION p_197401 VALUES IN (197401) ENGINE = InnoDB);
  3. 插入数据

    ps:插入数据的时候,可以指定分区。如果不指定分区,也会自行根据分区入库。

    java 复制代码
    insert into table_id partition(p_197401) (car_id,car_no)  values XXXXX;
相关推荐
威联通网络存储3 小时前
某高端显示面板制造企业:基于威联通 TS-h2490FU 的 AOI 检测数据治理实践
python·制造
某个默默无闻奋斗的人3 小时前
高性能 MySQL 进阶:索引核心原理、失效场景与底层优化全解
数据库·mysql
极限实验室5 小时前
INFINI Labs 产品更新 - Easysearch 2.1.0 新增高性能 Rules 规则引擎插件,数据探索 Discover 等
数据库·产品
鹿角片ljp7 小时前
苍穹外卖 day05:店铺营业状态设置与Redis入门实战
数据库·redis·缓存
FreakStudio7 小时前
不用装软件!这款MicroPython浏览器 IDE :让你在手机上也能调试树莓派 Pico
python·单片机·嵌入式·电子diy·tinyml
m0_743470378 小时前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
Demon_Hao8 小时前
JAVA通过Redis实现Key分区分片聚合点赞、收藏等计数同步数据库,并且通过布隆过滤器防重复点赞
java·数据库·redis
掘根8 小时前
【微服务即时通讯】消息转发子服务
数据库·oracle
喜欢喝果茶.8 小时前
SQL 预处理
数据库·sql
数据科学小丫10 小时前
Python 数据存储操作_数据存储、补充知识点:Python 与 MySQL交互
数据库·python·mysql