10

毎晩午後 11 時に実行されるストアド プロシージャを作成することは可能ですか? 過去 6 か月間にレコードが変更されたかどうかをテーブルで確認します。過去 6 か月間にレコードが変更された場合は、テーブルから削除する必要があります。これは、外部言語を使用せずに自動的に実行する必要があります。

4

4 に答える 4

14
CREATE EVENT IF NOT EXISTS `my_old_data_cleaner_event`
ON SCHEDULE EVERY 23 DAY_HOUR
COMMENT 'Clean up Service Start at 11:00PM daily!'
DO DELETE FROM my_table WHERE created_date < (NOW() - INTERVAL 1 MONTH);

または、ストアド プロシージャの場合。

CREATE EVENT IF NOT EXISTS `my_old_data_cleaner_event`
ON SCHEDULE EVERY 23 DAY_HOUR
DO CALL my_sp_cleanup_old_data();
于 2012-12-14T04:40:37.363 に答える
3

mysqlイベントスケジューラで達成できます--

http://dev.mysql.com/doc/refman/5.1/en/events.html

詳細ブログ: http://goo.gl/6Hzjvg

于 2012-12-14T04:25:33.777 に答える
0

以下のようなイベントを作成します

CREATE EVENT e_daily
  ON SCHEDULE
    EVERY 1 DAY
 DO
   BEGIN
     DELETE FROM tableA WHERE DATE(`yourtimestamp`) <(CURDATE() - INTERVAL 6 MONTHS);
  END 
于 2012-12-14T04:43:27.167 に答える
0

Python、Perl、PHP などでデータを処理するスクリプトを作成することもできます。

その後、crontab -e次の行を使用して cron エントリをセットアップし、追加します。

0 23 * * * /path/to/my/script.pl 2>&1 >/dev/null

を指定しない場合は2>&1 >/dev/null、実行結果が記載されたメールが届きます。

于 2012-12-14T04:45:05.210 に答える