国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL定時器常用案例

瀏覽:7日期:2023-07-20 19:52:12
目錄MySQL-定時器介紹開啟定時器定時器常用案例周期性周期一次性MySQL-定時器介紹

在開發(fā)過程中經(jīng)常會遇到這樣一個問題:每天或者每月必須定時去執(zhí)行一條sql語句或更新或刪除或執(zhí)行特定的sql語句。而遇到這樣的問題我想很多人會說,我直接在程序代碼里寫一個定時器不就行了,對你說的沒問題,但是有些時候只是數(shù)據(jù)層面的問題,那么我們在程序里寫一個定時器就有點浪費了,

比如:

定時清理臟數(shù)據(jù)在每月的月底統(tǒng)計這個月的業(yè)務(wù),將統(tǒng)計后的值放入統(tǒng)計表中分段定時導(dǎo)出批量數(shù)據(jù),進(jìn)行數(shù)據(jù)遷移定時整理其他系統(tǒng)推送來的數(shù)據(jù),然后將整理后的數(shù)據(jù)放入本系統(tǒng)業(yè)務(wù)表中…自行研究

可以看出來,mysql定時器作用其實挺大的,只是很多人都把它忽略了而已,但是缺陷也很明顯就是只能處理mysql內(nèi)已有的數(shù)據(jù),這個就看你自己了具體怎么使用了.

注意: mysql定時器是從mysql5.1開始的,如果你的mysql版本低于5.1,那就不能使用mysql定時器

開啟定時器

在使用定時器前必須檢查一下,mysql的定時器是否開啟的, 默認(rèn)是關(guān)閉的.

查詢定時器是否開啟OFF 關(guān)閉 , ON開啟

show VARIABLES like 'event_scheduler'

開啟mysql定時器

SET GLOBAL event_scheduler = 1;

然后我們在查詢下就是ON了,到這里我們mysql定時器開啟成功了

注意: 如果mysql服務(wù)器重啟這個還是會關(guān)閉的,

永久解決辦法:找到mysql根目錄下my.ini文件,打開并在[mysqld]標(biāo)記下方添加一句event_scheduler = ON即可。注意: 不要添加到[mysql]標(biāo)記下,而是[mysqld]標(biāo)記下,不然會配置無效。

重啟mysql 之后就會永久生效

使用sql語句創(chuàng)建定時器

為啥不使用Navicat創(chuàng)建定時器呢?, 反正我自我感覺的話,SQL比較踏實,使用Navicat創(chuàng)建定時器總是出現(xiàn)各種問題,我也不知道是不是軟件的問題,還是我自己的問題,反正用sql從來就沒有出現(xiàn)問題過.如果是簡單的定時器創(chuàng)建的話那么使用Navicat 創(chuàng)建也行,沒要求的…

先介紹下常用關(guān)鍵字的意思先別管怎么用的,后面參照案例代碼就懂了:

常用的語法關(guān)鍵字:

NOT PRESERVE 任務(wù)完成后清除定時器, (默認(rèn))PRESERVE 任務(wù)完成后不清除定時器EVERY 周期執(zhí)行STARTS ENDS 在某個時間段執(zhí)行AT 某個時間點執(zhí)行ENDS 結(jié)束定時器時間INTERVAL 間隔(時間)

常用的單位關(guān)鍵字:HOUR : 小時SECOND 秒MINUTE : 分鐘DAY : 天MONTH: 月

定時器語法結(jié)構(gòu):

DROP EVENT IF EXISTS 定時器名稱 ;CREATE EVENT user_event ON SCHEDULE xx -- 定時器從什么開始執(zhí)行的 (必須)ENDS CURRENT_TIMESTAMP xx -- 定時器開始后在什么時候結(jié)束 (非必選) ON COMPLETION xx -- 定時器清除策略 (默認(rèn)就行)DO sql語句 -- 定時器執(zhí)行的內(nèi)容,只允許一條sql語句以分號結(jié)束 (必須)

大致就是這樣,別糾結(jié),后面會舉幾個例子你參照參照就行了.

這里有一個地方需要注意:DO 后面能執(zhí)行的sql語句,只要mysql中有的都能執(zhí)行,但是每一個定時器只能執(zhí)行一個sql,如果多條sql的話,建議使用存儲過程,然后在使用定時器執(zhí)行存儲過程就行了

定時器常用案例周期性

定時器,一直執(zhí)行

從現(xiàn)在開始每隔x天執(zhí)行一次

DROP EVENT IF EXISTS user_event ;CREATE EVENT user_eventON SCHEDULE EVERY 9 DAY STARTS NOW()DO call user_procedure();

每天凌晨1點執(zhí)行

DROP EVENT IF EXISTS user_event ;CREATE EVENT user_eventon schedule EVERY 1 DAY STARTS date_add(date( ADDDATE(curdate(),1)),interval 1 hour) DO call user_procedure();

每個月的一號凌晨1 點執(zhí)行

DROP EVENT IF EXISTS 定時器名稱 ;CREATE EVENT user_eventON schedule every 1 month starts date_add(date_add(date_sub(curdate(),interval day(curdate())-1 day),interval 1 month),interval 1 hour)DO call user_procedure();

每個季度一號的凌晨1點執(zhí)行

DROP EVENT IF EXISTS user_event ;CREATE EVENT user_eventON schedule every 1 quarter starts date_add(date_add(date(concat(year(curdate()),'-',elt(quarter(curdate()),1,4,7,10),'-',1)),interval 1 quarter),interval 1 hour)DO call user_procedure();

每年1月1號凌晨1點執(zhí)行

DROP EVENT IF EXISTS user_event ;CREATE EVENT user_eventON schedule every 1 quarter starts date_add(date_add(date(concat(year(curdate()),'-',elt(quarter(curdate()),1,4,7,10),'-',1)),interval 1 quarter),interval 1 hour)DO call user_procedure(); 周期一次性

定時器執(zhí)行很多次后在滿足某個條件,定時器結(jié)束

從現(xiàn)在開始每天執(zhí)行一次,5天后停止執(zhí)行

DROP EVENT IF EXISTS user_event ;CREATE EVENT user_event ON SCHEDULE EVERY 1 DAY ENDS CURRENT_TIMESTAMP + INTERVAL 5 DAYDO call user_procedure();

從現(xiàn)在開始5天后開始執(zhí)行,一個月后停止執(zhí)行

DROP EVENT IF EXISTS user_event ;CREATE EVENT user_eventON SCHEDULE EVERY 1 DAY STARTS CURRENT_TIMESTAMP + INTERVAL 5 DAY ENDS CURRENT_TIMESTAMP + INTERVAL 1 MONTHDO call user_procedure();

一次性

滿足指定條件時只會執(zhí)行一次定時器,然后定時器被清除

在未來指定時間點執(zhí)行一次

DROP EVENT IF EXISTS user_event ;CREATE EVENT user_event ON SCHEDULE AT TIMESTAMP '2021-09-24 18:26:00' ON COMPLETION NOT PRESERVEDO call user_procedure();

在2021-09-24 18:26:00時候執(zhí)行user_procedure()存儲過程一次之后,該定時器被系統(tǒng)清除

從現(xiàn)在開始1小時后執(zhí)行一次

DROP EVENT IF EXISTS user_event ;CREATE EVENT user_event ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 HOUR ON COMPLETION NOT PRESERVEDO call user_procedure();

開啟和關(guān)閉指定定時器

alter event user_event on completion preserve enable; -- 開啟定時任務(wù)alter event user_event on completion preserve disable; -- 關(guān)閉定時任務(wù)

查看當(dāng)前用戶的定時任務(wù)

注意: 建議在創(chuàng)建定時器的時候使用,root用戶,這樣到時候統(tǒng)一管理也比較方便

能查看到定時器調(diào)用的sql

select * from information_schema.`EVENTS`;

能查看到定時器的狀態(tài)ENABLED(定時器使開啟狀態(tài))DISABLED (定時器使關(guān)閉狀態(tài))

select * from mysql.event;

到此這篇關(guān)于MySQL-定時器的文章就介紹到這了,更多相關(guān)mysql定時器內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫
主站蜘蛛池模板: 毛片在线播放a | 天堂资源8中文最新版在线 天堂最新版 | 久久成人18免费网站 | www.日本高清视频.com | 欧美国产日韩在线观看 | 国产91九色刺激露脸对白 | 久久精品国产99久久99久久久 | 亚洲精品不卡午夜精品 | 成人手机在线视频 | 精品国产杨幂在线观看福利 | 亚洲欧美国产中文 | 国产福利最新手机在线观看 | 国产在线精品一区二区不卡 | 中国性孕妇孕交在线 | 亚洲午夜在线观看 | 国产精品高清一区二区 | 成人在线免费网站 | 国内自拍视频在线看免费观看 | 91国内视频 | 怡红院免费在线视频 | 中文字幕一区二区在线播放 | 自拍视频啪| 91麻精品国产91久久久久 | 国产高清一区二区三区视频 | 国产欧美一区二区成人影院 | 欧美一区二区三区精品国产 | 日韩一区二区三区视频在线观看 | 国产成人精品一区二三区 | 久久精品免费一区二区视 | 99精品视频一区在线视频免费观看 | 日本免费高清视频二区 | 国产专区一区 | 亚洲一区二区三区久久 | 亚洲情a成黄在线观看 | 在线观看国产情趣免费视频 | 无码免费一区二区三区免费播放 | 天天看片天天爽_免费播放 天天看夜夜 | 男人看片网址 | 亚洲第一大网站 | 久久精品一区二区免费看 | 在线观看视频一区二区三区 |