ホームページ >データベース >mysql チュートリアル >MySQL イベントを毎日特定の時刻に実行するようにスケジュールするにはどうすればよいですか?

MySQL イベントを毎日特定の時刻に実行するようにスケジュールするにはどうすればよいですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-12-27 00:26:16623ブラウズ

How Can I Schedule a MySQL Event to Run Daily at a Specific Time?

毎日特定の時間に MySQL Event Scheduler を実行する

データベースがあり、毎日午後 1 時にレコードのステータスを「0」に更新する必要があると想像してください。最初に思いつくかもしれないクエリは次のとおりです。

CREATE EVENT
RESET ON SCHEDULE AT TIMESTAMP DO
UPDATE `ndic`.`students`
SET `status` = '0';  

しかし、そのクエリは TIMESTAMP を使用しているため、特定の時刻にスケジュールすることはできません。では、どうすればこの結果を達成できるでしょうか?

答えは STARTS キーワードにあります。毎日午後 1 時にイベントを実行する変更されたクエリを次に示します。

CREATE EVENT event_name
  ON SCHEDULE
    EVERY 1 DAY
    STARTS (TIMESTAMP(CURRENT_DATE) + INTERVAL 1 DAY + INTERVAL 1 HOUR)
  DO
    UPDATE `ndic`.`students`
    SET `status` = '0';

このクエリは、(CURRENT_DATE 1 DAY 1 HOUR) にイベントを開始し、その後 24 時間ごとに繰り返します。これにより、希望どおりに毎日午後 1 時にイベントがトリガーされるようになります。

以上がMySQL イベントを毎日特定の時刻に実行するようにスケジュールするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。