データベースがあり、毎日午後 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 サイトの他の関連記事を参照してください。