mysql 動態新建以及刪除分割槽表
drop procedure if exists general_procedure;
-- general_procedure的作用:新建分割槽表及在table_fen_qu表中儲存新建分割槽表時的相關引數
-- general_procedure的引數:表名,分割槽表之間的時間間隔(單位為小時),要新增的分割槽表個數
create procedure general_procedure(in tablenamein varchar(50),in intervalHour int,in newIntervalNum int)
general_pro:begin
-- 引數:最大時間
declare maxMonitTime datetime default SYSDATE();
-- 引數:最大時間對應的字串
declare maxMonitTimeStr varchar(50);
-- 引數:最小時間
declare minMonitTime datetime default SYSDATE();
-- 引數:最大時間對應的字串
declare minMonitTimeStr varchar(50);
-- 引數:資料庫記錄數
declare recoidNum int default 0;
-- 判斷傳入的表名是否為空
if tablenamein is null then
leave general_pro;
end if;
-- 判斷傳入的時間間隔
if intervalHour <= 0 then
set intervalHour = 6;
end if;
-- 判斷新增分割槽表個數
if newIntervalNum <= 0 then
set newIntervalNum = 1;
end if;
-- 在該表中,查詢符合條件的記錄數,backupflag=0說明是未備份
select count(*) into recoidNum from table_fen_qu where tablename=tablenamein and backupflag=0;
if recoidNum > 0 then
-- 查詢該表在table_fen_qu表中的最大監測時間
select monittime into maxMonitTime from table_fen_qu where tablename=tablenamein and backupflag=0 order by monittime desc limit 1;
-- 判斷監測時間是否為null
if maxMonitTime is null then
set maxMonitTime = SYSDATE();
end if;
-- 比較最大時間減去72個小時之後的時間與系統時間的早晚
set recoidNum = timestampdiff(hour,SYSDATE(),DATE_SUB(maxMonitTime,INTERVAL 3 DAY));
-- 如果recoidNum大於0,說明最大監測時間減去72小時之後的時間仍然在系統時間之後,
-- 說明不用建立新的分割槽表,反之,則建立最大監測時間之後newIntervalNum個以每intervalHour小時為間隔的分割槽表
if recoidNum <= 0 then
set recoidNum = 1;
while recoidNum <= newIntervalNum do
set maxMonitTime = ADDDATE(maxMonitTime,INTERVAL intervalHour HOUR);
set maxMonitTimeStr = CONCAT('p',DATE_FORMAT(maxMonitTime,"%Y%m%d%H%i%s"));
-- 開始新增分割槽表
-- 拼接分割槽表程式碼段
set @v_add_s = CONCAT('ALTER TABLE ',tablenamein,' ADD PARTITION (PARTITION ',maxMonitTimeStr,' VALUES LESS THAN (\'',maxMonitTime,'\') ENGINE = InnoDB )');
-- 定義預處理語句
prepare stmt from @v_add_s;
-- 執行預處理語句
execute stmt;
-- 釋放預處理語句
deallocate prepare stmt;
-- 開始在table_fen_qu中新增記錄
insert into table_fen_qu(fenquname,tablename,monittime,backupflag) VALUES(maxMonitTimeStr,tablenamein,maxMonitTime,0);
-- 記錄數加1
set recoidNum = recoidNum + 1;
end while;
end if;
else
set recoidNum = 2;
-- 計算最小時間
set minMonitTimeStr = CONCAT(DATE_FORMAT(DATE_SUB(maxMonitTime,INTERVAL 60 DAY),'%Y-%m-%d'),' 00:00:00');
set minMonitTime = STR_TO_DATE(minMonitTimeStr,'%Y-%m-%d %H:%i:%s');
-- 計算最大時間
set maxMonitTimeStr = CONCAT(DATE_FORMAT(ADDDATE(maxMonitTime,INTERVAL 4 DAY),'%Y-%m-%d'),' 00:00:00');
set maxMonitTime = STR_TO_DATE(maxMonitTimeStr,'%Y-%m-%d %H:%i:%s');
-- 計算新建表分割槽個數
set newIntervalNum = floor(timestampdiff(hour,minMonitTime,maxMonitTime) / intervalHour) + 1;
if newIntervalNum < 12 then
set newIntervalNum = 12;
end if;
-- 刪除所有表分割槽
set @v_del_s = CONCAT('ALTER TABLE ',tablenamein,' remove partitioning');
-- 定義預處理語句
prepare stmt from @v_del_s;
-- 執行預處理語句
execute stmt;
-- 釋放預處理語句
deallocate prepare stmt;
-- 刪除所有資料
delete from table_fen_qu where tablename= tablenamein;
-- 新建分割槽
-- 設定時間
set minMonitTimeStr = CONCAT('p',DATE_FORMAT(minMonitTime,"%Y%m%d%H%i%s"));
-- 拼接新增分割槽表sql
set @v_add_s = CONCAT('ALTER TABLE ',tablenamein,' PARTITION BY RANGE COLUMNS(moint_time) (PARTITION ',minMonitTimeStr,' VALUES LESS THAN (\'',minMonitTime,'\') ENGINE = InnoDB,');
-- 開始在table_fen_qu中新增記錄
insert into table_fen_qu(fenquname,tablename,monittime,backupflag) VALUES(minMonitTimeStr,tablenamein,minMonitTime,0);
while recoidNum <= newIntervalNum do
-- 設定時間
set minMonitTime = ADDDATE(minMonitTime,INTERVAL intervalHour HOUR);
set minMonitTimeStr = CONCAT('p',DATE_FORMAT(minMonitTime,"%Y%m%d%H%i%s"));
-- 拼接新增分割槽表sql
set @v_add_s = CONCAT(@v_add_s,'PARTITION ',minMonitTimeStr,' VALUES LESS THAN (\'',minMonitTime,'\') ENGINE = InnoDB,');
-- 開始在table_fen_qu中新增記錄
insert into table_fen_qu(fenquname,tablename,monittime,backupflag) VALUES(minMonitTimeStr,tablenamein,minMonitTime,0);
-- 記錄數加1
set recoidNum = recoidNum + 1;
end while;
set @v_add_s = left(@v_add_s,LENGTH(@v_add_s)-1);
set @v_add_s = CONCAT(@v_add_s,');');
-- 定義預處理語句
prepare stmt from @v_add_s;
-- 執行預處理語句
execute stmt;
-- 釋放預處理語句
deallocate prepare stmt;
end if;
end general_pro;
-- general_procedure的作用:新建分割槽表及在table_fen_qu表中儲存新建分割槽表時的相關引數
-- general_procedure的引數:表名,分割槽表之間的時間間隔(單位為小時),要新增的分割槽表個數
create procedure general_procedure(in tablenamein varchar(50),in intervalHour int,in newIntervalNum int)
general_pro:begin
-- 引數:最大時間
declare maxMonitTime datetime default SYSDATE();
-- 引數:最大時間對應的字串
declare maxMonitTimeStr varchar(50);
-- 引數:最小時間
declare minMonitTime datetime default SYSDATE();
-- 引數:最大時間對應的字串
declare minMonitTimeStr varchar(50);
-- 引數:資料庫記錄數
declare recoidNum int default 0;
-- 判斷傳入的表名是否為空
if tablenamein is null then
leave general_pro;
end if;
-- 判斷傳入的時間間隔
if intervalHour <= 0 then
set intervalHour = 6;
end if;
-- 判斷新增分割槽表個數
if newIntervalNum <= 0 then
set newIntervalNum = 1;
end if;
-- 在該表中,查詢符合條件的記錄數,backupflag=0說明是未備份
select count(*) into recoidNum from table_fen_qu where tablename=tablenamein and backupflag=0;
if recoidNum > 0 then
-- 查詢該表在table_fen_qu表中的最大監測時間
select monittime into maxMonitTime from table_fen_qu where tablename=tablenamein and backupflag=0 order by monittime desc limit 1;
-- 判斷監測時間是否為null
if maxMonitTime is null then
set maxMonitTime = SYSDATE();
end if;
-- 比較最大時間減去72個小時之後的時間與系統時間的早晚
set recoidNum = timestampdiff(hour,SYSDATE(),DATE_SUB(maxMonitTime,INTERVAL 3 DAY));
-- 如果recoidNum大於0,說明最大監測時間減去72小時之後的時間仍然在系統時間之後,
-- 說明不用建立新的分割槽表,反之,則建立最大監測時間之後newIntervalNum個以每intervalHour小時為間隔的分割槽表
if recoidNum <= 0 then
set recoidNum = 1;
while recoidNum <= newIntervalNum do
set maxMonitTime = ADDDATE(maxMonitTime,INTERVAL intervalHour HOUR);
set maxMonitTimeStr = CONCAT('p',DATE_FORMAT(maxMonitTime,"%Y%m%d%H%i%s"));
-- 開始新增分割槽表
-- 拼接分割槽表程式碼段
set @v_add_s = CONCAT('ALTER TABLE ',tablenamein,' ADD PARTITION (PARTITION ',maxMonitTimeStr,' VALUES LESS THAN (\'',maxMonitTime,'\') ENGINE = InnoDB )');
-- 定義預處理語句
prepare stmt from @v_add_s;
-- 執行預處理語句
execute stmt;
-- 釋放預處理語句
deallocate prepare stmt;
-- 開始在table_fen_qu中新增記錄
insert into table_fen_qu(fenquname,tablename,monittime,backupflag) VALUES(maxMonitTimeStr,tablenamein,maxMonitTime,0);
-- 記錄數加1
set recoidNum = recoidNum + 1;
end while;
end if;
else
set recoidNum = 2;
-- 計算最小時間
set minMonitTimeStr = CONCAT(DATE_FORMAT(DATE_SUB(maxMonitTime,INTERVAL 60 DAY),'%Y-%m-%d'),' 00:00:00');
set minMonitTime = STR_TO_DATE(minMonitTimeStr,'%Y-%m-%d %H:%i:%s');
-- 計算最大時間
set maxMonitTimeStr = CONCAT(DATE_FORMAT(ADDDATE(maxMonitTime,INTERVAL 4 DAY),'%Y-%m-%d'),' 00:00:00');
set maxMonitTime = STR_TO_DATE(maxMonitTimeStr,'%Y-%m-%d %H:%i:%s');
-- 計算新建表分割槽個數
set newIntervalNum = floor(timestampdiff(hour,minMonitTime,maxMonitTime) / intervalHour) + 1;
if newIntervalNum < 12 then
set newIntervalNum = 12;
end if;
-- 刪除所有表分割槽
set @v_del_s = CONCAT('ALTER TABLE ',tablenamein,' remove partitioning');
-- 定義預處理語句
prepare stmt from @v_del_s;
-- 執行預處理語句
execute stmt;
-- 釋放預處理語句
deallocate prepare stmt;
-- 刪除所有資料
delete from table_fen_qu where tablename= tablenamein;
-- 新建分割槽
-- 設定時間
set minMonitTimeStr = CONCAT('p',DATE_FORMAT(minMonitTime,"%Y%m%d%H%i%s"));
-- 拼接新增分割槽表sql
set @v_add_s = CONCAT('ALTER TABLE ',tablenamein,' PARTITION BY RANGE COLUMNS(moint_time) (PARTITION ',minMonitTimeStr,' VALUES LESS THAN (\'',minMonitTime,'\') ENGINE = InnoDB,');
-- 開始在table_fen_qu中新增記錄
insert into table_fen_qu(fenquname,tablename,monittime,backupflag) VALUES(minMonitTimeStr,tablenamein,minMonitTime,0);
while recoidNum <= newIntervalNum do
-- 設定時間
set minMonitTime = ADDDATE(minMonitTime,INTERVAL intervalHour HOUR);
set minMonitTimeStr = CONCAT('p',DATE_FORMAT(minMonitTime,"%Y%m%d%H%i%s"));
-- 拼接新增分割槽表sql
set @v_add_s = CONCAT(@v_add_s,'PARTITION ',minMonitTimeStr,' VALUES LESS THAN (\'',minMonitTime,'\') ENGINE = InnoDB,');
-- 開始在table_fen_qu中新增記錄
insert into table_fen_qu(fenquname,tablename,monittime,backupflag) VALUES(minMonitTimeStr,tablenamein,minMonitTime,0);
-- 記錄數加1
set recoidNum = recoidNum + 1;
end while;
set @v_add_s = left(@v_add_s,LENGTH(@v_add_s)-1);
set @v_add_s = CONCAT(@v_add_s,');');
-- 定義預處理語句
prepare stmt from @v_add_s;
-- 執行預處理語句
execute stmt;
-- 釋放預處理語句
deallocate prepare stmt;
end if;
end general_pro;
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/23490154/viewspace-1063384/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle分割槽表基礎運維-09刪除分割槽Oracle運維
- ORACLE刪除-表分割槽和資料Oracle
- MySQL線上轉分割槽表(以及TiDB)MySqlTiDB
- SQL Server表分割槽刪除詳情DSCCSQLServer
- 【MYSQL】 分割槽表MySql
- MySQL 分割槽表探索MySql
- Hive的靜態分割槽與動態分割槽Hive
- win10 oem分割槽怎麼刪除_win10 oem分割槽可以刪除嗎Win10
- hive 動態分割槽插入資料表Hive
- Mysql表分割槽實現MySql
- mysql 進行表分割槽MySql
- Mysql表分割槽實操MySql
- Hive動態分割槽Hive
- Hive中靜態分割槽和動態分割槽總結Hive
- 非分割槽錶轉換成分割槽表以及注意事項
- 移動分割槽表和分割槽索引的表空間索引
- MySQL調優之分割槽表MySql
- MySQL 分割槽表知識整理MySql
- win10分割槽好了怎麼刪除_win10分割槽完後如何刪除Win10
- oracle分割槽表和分割槽表exchangeOracle
- windows10分割槽無法刪除怎麼辦_win10系統磁碟刪除分割槽的方法WindowsWin10
- win10刪除系統保留分割槽如何操作_win10刪除系統保留分割槽怎麼處理Win10
- 電腦硬碟分割槽要注意什麼,刪除硬碟分割槽的注意事項硬碟
- (3) MySQL分割槽表使用方法MySql
- MySQL資料表分割槽手記MySql
- 實現MySQL表結構自動分割槽指令碼MySql指令碼
- Hive動態分割槽詳解Hive
- mysql~關於mysql分割槽表的測試MySql
- oracle分割槽表和非分割槽表exchangeOracle
- 分割槽表之自動增加分割槽(11G)
- mysql 分割槽MySql
- mysql分割槽表佔用大量容量處理(最佳化)及歸檔分割槽表MySql
- 刪除EFI系統分割槽(ESP)後Windows無法啟動,重建引導分割槽並修復啟動的過程Windows
- 第41期:MySQL 雜湊分割槽表MySql
- 第40期:MySQL 分割槽表案例分享MySql
- MySql分表、分庫、分片和分割槽MySql
- MySQL分表後原分割槽表處理方案MySql
- 非 LVM 分割槽動態擴容LVM
- PostgreSQL/LightDB 分割槽表之分割槽裁剪SQL