MySQL按時間進行表分區(qū)的方法代碼
更新時間:2024年09月29日 10:47:56 作者:逢生博客
本文介紹如何在MySQL中創(chuàng)建按月份分區(qū)的表,并通過修改配置文件或使用數(shù)據庫事件來實現(xiàn)自動分區(qū),文中通過代碼介紹的非常詳細,對大家學習或者使用MySQL具有一定的參考借鑒價值,需要的朋友可以參考下
創(chuàng)建按月份分區(qū)的表
create table if not exists table_name ( id bigint auto_increment comment '主鍵id', create_by varchar(64) not null comment '創(chuàng)建者', create_time datetime default CURRENT_TIMESTAMP not null comment '創(chuàng)建時間', update_by varchar(64) null comment '更新者', update_time datetime default CURRENT_TIMESTAMP null on update CURRENT_TIMESTAMP comment '更新時間', primary key (id, create_time) ) comment '測試表名' partition by range (TO_DAYS(create_time)) ( partition P202401 values less than (TO_DAYS('2024-02-01')) , partition P202402 values less than (TO_DAYS('2024-03-01')) , partition P202403 values less than (TO_DAYS('2024-04-01')) , partition P202404 values less than (TO_DAYS('2024-05-01')) );
開啟數(shù)據庫事件
臨時配置(服務重啟會失效)
-- 開啟事件 SET GLOBAL event_scheduler = ON; -- 查看事件是否開啟 SHOW VARIABLES LIKE '%event_sche%';
修改my.cnf文件(推薦)
- 進入MySQL所在的服務器
sudo vi /etc/my.cnf
- 找到 [mysqld],添加如下內容
event_scheduler = ON
- 重啟 MySQL 服務以使更改生效
sudo systemctl restart mysqld
定時事件自動建分區(qū)
- 例:提前創(chuàng)建下個月的分區(qū),如2024-04-01創(chuàng)建5月份的分區(qū) P202405,2024-05-01創(chuàng)建6月份的分區(qū)。
create event event_create_partition on schedule every '1' MONTH starts '2024-04-01 00:00:00' on completion preserve enable do BEGIN -- 當前時間 2024-04-01 00:00:00 -- _DATE = 2024-05-01 DECLARE _DATE VARCHAR(10) DEFAULT ADDDATE(SUBDATE(CURDATE(), DAY(CURDATE()) - 1), INTERVAL 1 MONTH); -- P202405 SET @PARTITION_NAME = CONCAT('P', DATE_FORMAT(_DATE, '%Y%m')); -- 2024-06-01 SET @SHEAR_DATE = CONCAT('', ADDDATE(LAST_DAY(_DATE), 1)); SET @SQL = CONCAT('ALTER TABLE table_name ADD PARTITION (PARTITION ', @PARTITION_NAME, ' VALUES LESS THAN (TO_DAYS("', @SHEAR_DATE, '")))'); PREPARE STMT FROM @SQL; EXECUTE STMT; DEALLOCATE PREPARE STMT; END;
注意: 數(shù)據庫
event_scheduler = ON
要確認有開啟,否則 event_create_partition 事件不會執(zhí)行。
- 查看所有事件
SHOW EVENTS;
查詢表分區(qū)信息
SELECT TABLE_SCHEMA, TABLE_NAME, PARTITION_NAME, PARTITION_METHOD, PARTITION_EXPRESSION, SUBPARTITION_NAME, SUBPARTITION_METHOD, SUBPARTITION_EXPRESSION FROM information_schema.partitions WHERE TABLE_SCHEMA = '數(shù)據庫名' AND TABLE_NAME IN ('table_name') ORDER BY PARTITION_NAME DESC;
總結
到此這篇關于MySQL按時間進行表分區(qū)的文章就介紹到這了,更多相關MySQL按時間表分區(qū)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Mysql使用on update current_timestamp問題
這篇文章主要介紹了Mysql使用on update current_timestamp問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03MySQL 中查詢 VARCHAR 類型 JSON 數(shù)據的問題記錄
在數(shù)據庫設計中,有時我們會將 JSON 數(shù)據存儲在 VARCHAR 或 TEXT 類型字段中,本文將詳細介紹如何在 MySQL 中有效查詢存儲為 VARCHAR 類型的 JSON 數(shù)據,感興趣的朋友一起看看吧2025-04-04