MySQL 是一種開放源代碼的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)。在開發(fā)過程中,我們經(jīng)常需要執(zhí)行定時(shí)任務(wù)來保證數(shù)據(jù)的更新、清理等操作。為此,我們可以使用 MySQL 定時(shí)執(zhí)行 sql。
MySQL 提供了多個(gè)方法來實(shí)現(xiàn)定時(shí)任務(wù)。最簡單的方法是使用系統(tǒng)的計(jì)劃任務(wù)/任務(wù)計(jì)劃程序(例如 cron)。我們可以通過在計(jì)劃任務(wù)中運(yùn)行 mysql 命令來執(zhí)行 SQL 查詢。
# 執(zhí)行 sql 腳本 mysql -uroot-p< database_name< /path/to/sql_script.sql
但是,這種方式實(shí)現(xiàn)起來比較繁瑣,需要手動(dòng)創(chuàng)建 cron 任務(wù),并且代碼也較為冗長。MySQL 提供了更加簡單的定時(shí)任務(wù)方式 - 事件(Event)。
事件是在指定時(shí)間或間隔內(nèi)定期執(zhí)行的任務(wù)。通過使用事件,我們可以通過 SQL 查詢直接在 MySQL 數(shù)據(jù)庫中創(chuàng)建和管理定期執(zhí)行的任務(wù)。
# 示例:每天凌晨 3 點(diǎn)執(zhí)行 sql 操作 CREATE EVENT `daily_cleanup` ON SCHEDULE EVERY '1' DAY STARTS '2022-01-01 03:00:00' DO DELETE FROM `table1` WHERE `created_at`< DATE_SUB(NOW(), INTERVAL 30 DAY);
上面的代碼將在每天凌晨 3 點(diǎn)執(zhí)行一次查詢,刪除 table1 表中 30 天之前的數(shù)據(jù)。
為了使用事件,我們需要確保 MySQL 服務(wù)器啟用了事件調(diào)度器。我們可以通過以下 SQL 查詢檢查調(diào)度器狀態(tài):
SHOW VARIABLES LIKE 'event_scheduler';
如果調(diào)度器未啟用,則可以使用以下 SQL 查詢啟用它:
SET GLOBAL event_scheduler = ON;
關(guān)于 MySQL 的事件以及 SQL 查詢的更多細(xì)節(jié)和示例,請(qǐng)查閱 MySQL 官方文檔。