mysql table partition stored procedure

This article is original by the blogger and may not be reproduced without permission:

  Since there are tens of millions of data in a table in the database, and it is growing, seeing the company's predecessors wrote a stored procedure for creating table partitions, I feel

It's so awesome, I'll keep it here for myself to learn.

/*PROCEDURE create_partition_by_month*/
DROP PROCEDURE IF EXISTS `create_partition_by_month`;
DELIMITER $$
CREATE PROCEDURE `create_partition_by_month`(IN_TABLENAME VARCHAR(64))
BEGIN
    DECLARE ROWS_CNT INT UNSIGNED;
    DECLARE EXPIRE_ROWS_CNT INT UNSIGNED;
    DECLARE START TIME TIMESTAMP;
    DECLARE ENDTIME TIMESTAMP;
    DECLARE PARTITIONNAME VARCHAR(16);
    DECLARE PARTITIONRANGE INT UNSIGNED;
    DECLARE EXPIRETIME TIMESTAMP;
    DECLARE EXPIREPARTITION VARCHAR(16);
    
    SET BEGINTIME = DATE(NOW() - INTERVAL DAY(NOW()) DAY + INTERVAL 1 DAY + INTERVAL 1 MONTH);
    SET PARTITIONNAME = DATE_FORMAT( BEGINTIME, ' p%Y%m ' );
    SET ENDTIME = DATE(NOW() - INTERVAL DAY(NOW()) DAY + INTERVAL 1 DAY + INTERVAL 2 MONTH);
    SET PARTITIONRANGE = extract(YEAR_MONTH FROM ENDTIME);
    SET EXPIRETIME = DATE(NOW() - INTERVAL 3 YEAR);
    SET EXPIREPARTITION = DATE_FORMAT( EXPIRETIME, 'p%Y%m' );
    
    SELECT COUNT(*) INTO ROWS_CNT FROM information_schema.partitions WHERE  table_name = IN_TABLENAME AND partition_name = PARTITIONNAME;
    IF ROWS_CNT = 0 THEN
        SET @SQL = CONCAT( 'ALTER TABLE `', IN_TABLENAME, '`',
        ' ADD PARTITION (PARTITION ', PARTITIONNAME, ' VALUES LESS THAN (', PARTITIONRANGE ,') ENGINE = InnoDB);' );
        PREPARE STMT FROM @SQL;
        EXECUTE STMT;
        DEALLOCATE PREPARE STMT;
    ELSE
        SELECT CONCAT("partition `", PARTITIONNAME, "` for table `", IN_TABLENAME, "` already exists") AS result;
    END IF;
    
    SELECT COUNT(*) INTO EXPIRE_ROWS_CNT FROM information_schema.partitions WHERE  table_name = IN_TABLENAME AND partition_name = EXPIREPARTITION;
    IF EXPIRE_ROWS_CNT = 0 THEN
          SELECT CONCAT("partition `", EXPIREPARTITION, "` for table `", IN_TABLENAME, "` not exists") AS result;
    ELSE
          SET @SQL = CONCAT( 'ALTER TABLE `', IN_TABLENAME, '`', ' DROP PARTITION ', PARTITIONNAME, ';' );
        PREPARE STMT FROM @SQL;
        EXECUTE STMT;
        DEALLOCATE PREPARE STMT;
    END IF;
    
END$$
DELIMITER ;
/*EVENT e_alarm_partition*/
DROP EVENT IF EXISTS `e_alarm_partition`;
DELIMITER $$
CREATE EVENT IF NOT EXISTS `e_alarm_partition`
ON SCHEDULE EVERY 1 DAY #Execution cycle, as well as days, months, etc.
STARTS '2017-12-23 04:00:00'
ON COMPLETION PRESERVE
ENABLE
COMMENT 'Creating partitions'
DO BEGIN
    CALL create_partition_by_month('tbl_alarminfo');
    CALL create_partition_by_month('tbl_user_log');
END$$
DELIMITER ;

SET GLOBAL group_concat_max_len=102400;
SET SESSION group_concat_max_len=102400;
tbl_alarminfo is the alarm information table, tbl_user_log is the log operation record table

Guess you like

Origin http://43.154.161.224:23101/article/api/json?id=325302566&siteId=291194637