目錄
✅ 2. Create an Event to Run at a Specific Time
Example: Run a cleanup query once on a specific date/time
✅ 3. Schedule Recurring Events
Example: Run daily at 1:00 AM starting from today
✅ 4. Common Scheduling Patterns
✅ 5. Manage Events
✅ 6. Best Practices & Tips
✅ Summary
首頁 資料庫 mysql教程 如何在MySQL中安排事件以在特定時間運行?

如何在MySQL中安排事件以在特定時間運行?

Aug 08, 2025 pm 05:43 PM
定時任務

要使用MySQL事件調度器在特定時間安排事件,首先需啟用事件調度器,然後創建一次性或週期性事件,最後通過相關命令管理事件;具體步驟為:1. 執行SET GLOBAL event_scheduler = ON啟用事件調度功能;2. 使用CREATE EVENT結合AT指定具體時間執行SQL操作,如DELETE FROM logs WHERE created_at

How to schedule events in MySQL to run at specific times?

To schedule events in MySQL to run at specific times, you use MySQL's Event Scheduler —a built-in feature that allows you to automate tasks (like running SQL statements) at predefined times or intervals.

How to schedule events in MySQL to run at specific times?

Here's how to set it up and schedule events effectively:


✅ 1. Enable the Event Scheduler

By default, the event scheduler might be disabled . You need to turn it on.

How to schedule events in MySQL to run at specific times?

Check the current status:

 SHOW VARIABLES LIKE 'event_scheduler';

Enable it (if it's OFF):

How to schedule events in MySQL to run at specific times?
 SET GLOBAL event_scheduler = ON;

⚠️ Note: This change may not persist after a MySQL restart unless you add event_scheduler=ON to your my.cnf or my.ini configuration file.


✅ 2. Create an Event to Run at a Specific Time

Use the CREATE EVENT statement to define when and what should run.

Example: Run a cleanup query once on a specific date/time

 CREATE EVENT delete_old_logs
ON SCHEDULE AT '2025-04-05 02:00:00'
DO
  DELETE FROM logs WHERE created_at < &#39;2025-01-01&#39;;

This event runs once at April 5, 2025, at 2:00 AM.


✅ 3. Schedule Recurring Events

Use EVERY with STARTS and optional ENDS to run events repeatedly.

Example: Run daily at 1:00 AM starting from today

 CREATE EVENT daily_stats_summary
ON SCHEDULE EVERY 1 DAY
STARTS &#39;2025-04-05 01:00:00&#39;
DO
  CALL generate_daily_report();

You can also use expressions:

 STARTS NOW() INTERVAL 1 DAY

Or end the scheduling after a certain time:

 ON SCHEDULE EVERY 1 HOUR
STARTS CURRENT_TIMESTAMP
ENDS CURRENT_TIMESTAMP INTERVAL 1 WEEK

✅ 4. Common Scheduling Patterns

Goal Syntax
Run every 5 minutes EVERY 5 MINUTE
Run every day at 3 AM EVERY 1 DAY STARTS &#39;2025-04-05 03:00:00&#39;
Run once in 2 hours AT CURRENT_TIMESTAMP INTERVAL 2 HOUR
Run every Monday at 9 AM EVERY 1 WEEK STARTS &#39;2025-04-07 09:00:00&#39; (assuming Monday is Apr 7)

✅ 5. Manage Events

List all events:

 SHOW EVENTS;

Or for a specific database:

 SHOW EVENTS FROM your_database_name;

View detailed event info:

 SELECT * FROM information_schema.EVENTS WHERE EVENT_NAME = &#39;your_event&#39;;

Drop an event:

 DROP EVENT IF EXISTS delete_old_logs;

Alter an existing event (MySQL supports limited ALTER):

 ALTER EVENT daily_stats_summary
ENABLE;

-- Or disable
ALTER EVENT daily_stats_summary
DISABLE;

You can also use ALTER to change timing or action.


✅ 6. Best Practices & Tips

  • Always test your event logic first by running the SQL manually.
  • Use DEFINER if permissions matter:
     CREATE DEFINER = &#39;admin&#39;@&#39;localhost&#39; EVENT ...
  • Avoid long-running queries during peak hours.
  • Monitor event execution via logs or status checks.
  • Be cautious with ON COMPLETION NOT PRESERVE (default)—events are dropped after one-time execution unless PRESERVE is used.

Example preserving a one-time event:

 CREATE EVENT temp_backup
ON SCHEDULE AT &#39;2025-04-10 00:00:00&#39;
ON COMPLETION PRESERVE
DO
  INSERT INTO audit VALUES (&#39;Backup done&#39;);

✅ Summary

To schedule events in MySQL:

  1. Enable the event scheduler ( SET GLOBAL event_scheduler = ON )
  2. Write a CREATE EVENT statement with AT (one-time) or EVERY ... STARTS (recurring)
  3. Define the SQL command or stored procedure in the DO block
  4. Monitor and manage events using SHOW EVENTS , ALTER , or DROP

It's a powerful way to automate maintenance, reporting, or cleanup tasks directly inside the database.

Basically, if your MySQL server is running, the event scheduler will handle timed jobs—no external cron needed.

以上是如何在MySQL中安排事件以在特定時間運行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1605
29
PHP教程
1510
276
crontab定時任務不執行的一些原因,你知道嗎? crontab定時任務不執行的一些原因,你知道嗎? Mar 09, 2024 am 09:49 AM

crontab定時任務不執行的一些緣由總結更新時間:2019年01月09日09:34:57作者:田野上的希望這篇文章主要給你們總結介紹了關於crontab定時任務不執行的一些緣由,對每種可能發生的誘因都給出了解決方式,對遇見這個問題的同事們具有一定的參考學習價值,須要的同學們下邊隨著小編來一起學習學習吧序言近來在工作中遇見了一些問題, crontab定時任務竟然不執行,後來我在網上找的時侯發覺網上主要說了這5個誘因:1crond服務未啟動crontab不是Linux內核的功能,而是依賴一個cron

如何在FastAPI中實現定時任務和週期性任務 如何在FastAPI中實現定時任務和週期性任務 Jul 30, 2023 pm 03:53 PM

如何在FastAPI中實現定時任務和週期性任務引言:FastAPI是一個現代化的、高度效能的Python框架,專注於建立API應用程式。然而,有時我們需要在FastAPI應用程式中執行定時任務和週期性任務。本文將介紹如何在FastAPI應用程式中實作這些任務,並提供對應的程式碼範例。一、定時任務的實作使用APScheduler庫APScheduler是一個功能

如何在FastAPI中使用定時任務來執行後台工作 如何在FastAPI中使用定時任務來執行後台工作 Jul 28, 2023 pm 02:22 PM

如何在FastAPI中使用定時任務來執行後台工作隨著互聯網應用的快速發展,許多應用中都存在一些後台任務需要定期執行,例如資料清理、郵件發送、備份等。為了解決這個問題,我們可以使用定時任務來實現後台工作的自動執行。在本文中,將介紹如何在FastAPI框架中使用定時任務來執行後台工作。 FastAPI是一個現代、快速(高效能)的Web框架,主要用來建構API。它具

ThinkPHP6定時任務調度:定時執行任務 ThinkPHP6定時任務調度:定時執行任務 Aug 12, 2023 pm 03:28 PM

ThinkPHP6定時任務排程:定時執行任務一、簡介在Web應用程式開發過程中,常會遇到需要定期執行某些重複性任務的情況。 ThinkPHP6提供了強大的定時任務排程功能,能夠輕鬆實現定時執行任務的需求。本文將介紹如何在ThinkPHP6中使用定時任務調度,以及提供一些程式碼範例幫助理解。二、設定定時任務建立定時任務檔案在專案的app目錄下建立一個comman

PHP中如何進行任務排程與定時任務? PHP中如何進行任務排程與定時任務? May 12, 2023 pm 06:51 PM

在Web開發中,許多網站和應用程式需要定期執行一些任務,例如清理垃圾資料、發送郵件等。為了自動化這些任務,開發人員需要實現任務排程和定時任務的功能。本文將介紹PHP如何實現任務調度和定時任務,以及一些常用的第三方函式庫和工具。一、任務調度任務調度是指依照規定的時間或事件來執行某些任務。在PHP中,實作任務調度可以使用cron定時器或類似的機制。通常情況下,任務調度

Spring Boot的任務排程與定時任務實作方法 Spring Boot的任務排程與定時任務實作方法 Jun 22, 2023 pm 11:58 PM

SpringBoot是一款非常受歡迎的Java開發框架,不僅具有快速開發的優勢,而且還內建了許多實用的功能,其中,任務調度和定時任務就是其常用的功能之一。本文將探討SpringBoot的任務調度和定時任務實現方法。一、SpringBoot任務調度簡介SpringBoot任務調度(TaskScheduling)是指在特定的時間點或某個條件下,執行一些特

Python實作無頭瀏覽器擷取應用程式的頁面自動刷新與定時任務功能解析 Python實作無頭瀏覽器擷取應用程式的頁面自動刷新與定時任務功能解析 Aug 08, 2023 am 08:13 AM

Python實現無頭瀏覽器擷取應用的頁面自動刷新與定時任務功能解析隨著網路的快速發展和應用的普及,網頁資料的擷取變得越來越重要。而無頭瀏覽器則是收集網頁資料的有效工具之一。本文將介紹如何使用Python實作無頭瀏覽器的頁面自動刷新和定時任務功能。無頭瀏覽器採用的是無圖形介面的瀏覽器操作模式,能夠以自動化的方式模擬人類的操作行為,從而實現訪問網頁、點擊按鈕、填

如何使用PHP開發網頁定時刷新功能 如何使用PHP開發網頁定時刷新功能 Aug 17, 2023 pm 04:25 PM

如何使用PHP開發網頁定時刷新功能隨著互聯網的發展,越來越多的網站需要即時更新顯示資料。而即時刷新頁面是一種常見的需求,它可以讓使用者在不刷新整個頁面的情況下獲得最新的資料。本文將介紹如何使用PHP開發網頁定時刷新功能,並提供程式碼範例。使用Meta標籤定時刷新最簡單的實作方式是使用HTML的Meta標籤來進行頁面定時刷新。在HTML的&lt;head&gt;

See all articles