日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

MySQL中存儲(chǔ)過程+事件的使用方法

系統(tǒng) 2636 0

一、背景

將界面操作日志存儲(chǔ)在MySQL數(shù)據(jù)庫中的operationlog表中,如果該表不能自動(dòng)備份,表中的數(shù)據(jù)會(huì)越來越多,影響速度。可以定期將表中數(shù)據(jù)備份到另外一個(gè)表中來解決。

二、解決方案

1、使用MySQL中的存儲(chǔ)過程+事件解決。

  存儲(chǔ)過程邏輯為:

  1)創(chuàng)建一個(gè)新表operationlog_temp,各字段同operationlog相同;

  2)將表operationlog更名為operationlog_yyyy-mm-dd;

  3)將表operationlog_temp更名為operationlog

  事件邏輯為:

  1)每個(gè)3個(gè)月定時(shí)調(diào)用一次存儲(chǔ)過程bakOpLog

2、定義存儲(chǔ)過程bakOpLog:

【注】
開始事件功能(MySQL必須先開啟事件功能,才能使用事件),用如下SQL語句
SHOW VARIABLES LIKE 'event_scheduler';
SET GLOBAL event_scheduler = ON;

      CREATE DEFINER=`sa`@`%` PROCEDURE `bakOpLog`()

BEGIN

create table operationlog_temp like operationlog;

set @i=current_date();

--執(zhí)行rename table operationlog to operationlog_yyyy-mm-dd

set @sqlstr=CONCAT('rename table operationlog to `operationlog_',cast(@i as char),'`'); 

select @sqlstr;

PREPARE renameOpLog FROM @sqlstr;

EXECUTE renameOpLog;

rename table operationlog_temp to operationlog;

END;


    

3、定義事件callProcedureBakOpLog

      CREATE DEFINER=`sa`@`%` EVENT `callProcedureBakOpLog` ON SCHEDULE EVERY 1 DAY STARTS '2014-12-30 00:00:00' ENDS '2015-01-06 00:00:00' ON COMPLETION PRESERVE ENABLE DO call bakOpLog();
    

4、存儲(chǔ)過程用到的一些語法

      set @i=current_date();	//將全局變量i賦值為當(dāng)前日期

set @sqlstr=CONCAT('rename table operationlog to `operationlog_',cast(@i as char),'`');	//sqlstr=rename table operationlog to operationlog_yyyy-mm-dd

PREPARE renameOpLog FROM @sqlstr;	//定義預(yù)處理語句

EXECUTE renameOpLog;	//執(zhí)行預(yù)處理語句



查看創(chuàng)建的事件

SHOW EVENTS;

也可以在mysql庫中產(chǎn)看event表



1) 臨時(shí)關(guān)閉事件

ALTER EVENT e_test DISABLE;

2) 開啟事件

ALTER EVENT e_test ENABLE;

3) 將每天清空test表改為5天清空一次:

ALTER EVENT e_test

ON SCHEDULE EVERY 5 DAY;

4) 刪除事件(DROP EVENT)

DROP EVENT [IF EXISTS] event_name

例如刪除前面創(chuàng)建的e_test事件

DROP EVENT e_test;

當(dāng)然前提是這個(gè)事件存在,否則會(huì)產(chǎn)生ERROR 1513 (HY000): Unknown event錯(cuò)誤,因此最好加上IF EXISTS

DROP EVENT IF EXISTS e_test;
    

5、使用MySQL管理工具M(jìn)ySQL-Front操作存儲(chǔ)過程、事件的簡(jiǎn)介操作

  1)定義存儲(chǔ)過程、事件

MySQL中存儲(chǔ)過程+事件的使用方法

  2)直接在mysql庫中查看event表,該表中有定義過的事件

?   MySQL中存儲(chǔ)過程+事件的使用方法

MySQL中存儲(chǔ)過程+事件的使用方法


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 临沂市| 黄陵县| 新河县| 赤水市| 金湖县| 呼伦贝尔市| 奉贤区| 利辛县| 绥化市| 新疆| 合阳县| 谢通门县| 南漳县| 扶风县| 阿尔山市| 阜康市| 墨脱县| 开原市| 柘城县| 玉树县| 方城县| 黄龙县| 阳曲县| 泊头市| 蒙阴县| 通许县| 民乐县| 通化县| 晋城| 崇礼县| 阿克苏市| 大兴区| 玉门市| 永胜县| 吴川市| 大石桥市| 社会| 临澧县| 新河县| 远安县| 通道|