MySQLはトリガーを使用してデータベース内のテーブルの行制限を解決します。詳細な説明と例

MySQLはトリガーを使用してデータベース内のテーブルの行制限を解決します。詳細な説明と例

MySQLはトリガーを使用してデータベース内のテーブルの行制限を解決します。詳細な説明と例

最近のプロジェクト要件では、操作ログの数を 10 万件に制限しています。10 万件を超える場合は、最も古いログが削除され、データベースに保存されるログの数は 10 万件を超えません。
最初に考えたのはトリガーを使うことだったので、データベースで次の SQL を実行しました。

区切り文字 $
トリガー limitLog を作成する
前に
入れる
OperationLogで
各行ごとに
始める
(OperationLogからcount(*)を選択) > 100000の場合
OperationLog 制限 1 から削除します。
終了の場合;
終了$

区切り文字 ;

問題はないようです。挿入前にチェックが行われ、10万を超えると削除が実行されます。しかし、実際のデータベースが 100,000 レコードを超えると、IF ステートメントの実行開始時に問題が発生し、MySQL はエラーを報告します。

エラー 1442 (HY000): 保存されたテーブル 'OperationLog' を更新できません 
関数/トリガーは、呼び出されたステートメントによって既に使用されているため、 
この保存された関数/トリガー。

情報を調べてみると、トリガーの再帰的な無限ループの実行を防ぐために、MySQL では特定のテーブルのトリガー内でテーブルに直接 DML (SELECT、DELETE、UPDATE、INSERT) 操作を実行できないようになっていることがわかりました。もちろん、他のテーブルではそのような操作を実行できます。

トリガーは、テーブルで実行できる DML 操作を制限します。トリガーは、set キーワードを使用して、実行前または実行後に実行されるデータ行を変更できます。

区切り文字 $
トリガーsetLogを作成する
前に
入れる
OperationLogで
各行ごとに
始める
NEW.action = 'test' を設定します。
終了$

区切り文字 ;

上記のステートメントは、OpetationLog テーブルを挿入する前に、挿入されたデータのアクション フィールドの値がテストに更新されることを示しています。NEW は新しく追加されたフィールドを示し、OLD は削除されたときのフィールドを示します。アップデートの際はNEWとOLDを同時に使用できます。

一時的なトリガー

先ほど説明したトリガーは、特定のテーブルによって生成されたイベントに基づいてトリガーされますが、イベント スケジューラとも呼ばれる一時トリガーは、特定のタスクを実行するために特定の期間に基づいてトリガーされます。 MySQL のイベント スケジューラはタスクを 1 秒単位で正確に実行できますが、オペレーティング システムのスケジュールされたタスク (Linux の CRON や Windows のタスク スケジューリングなど) は 1 分に 1 回しか正確に実行できません。リアルタイムデータ(株価、オッズ、スコアなど)に対する要件が高いアプリケーションに非常に適しています。

この関数を使用する前に、event_schedulerが有効で実行可能であることを確認する必要があります。

 グローバルイベントスケジューラ = 1;

または

グローバルイベントスケジューラを ON に設定します。

イベント スケジューラが現在有効になっているかどうかを確認するには、次の SQL を実行します。

'event_scheduler' のような変数を表示します。

または

@@event_schedulerを選択します。

または

プロセスリストを表示します。

この記事の冒頭で述べた問題に関しては、このメカニズムは完璧に解決できます。

区切り文字 $
イベント limitLog を作成し、1 秒ごとにスケジュールを設定します。DO IF (select count(*) from OperationLog) > 100000 then delete from OperationLog limit 1;END IF $
 区切り文字 ;

実証された有効性

読んでいただきありがとうございます。お役に立てれば幸いです。このサイトをサポートしていただきありがとうございます。

以下もご興味があるかもしれません:
  • MySQLデータベーストリガーの詳細な説明
  • MySQL ストアド プロシージャ、トリガー、イベント スケジューラの入門ガイド
  • MySQLトリガートリガー例の詳細な説明
  • MySQL トリガーの使用方法と利点と欠点の紹介
  • MySQLトリガーの使用
  • MySQLトリガーについて深く理解するための記事
  • MySQLトリガーの使用
  • MySQLトリガーの例の詳細な説明
  • 初心者から熟練者まで使えるMySQLデータベーストリガー

<<:  Nginx 仮想ホスト (IP ベース) を構成する 3 つの方法の詳細な説明

>>:  Vue で親子コンポーネントの値を双方向バインドするために v-model を使用するときに発生する問題と解決策

推薦する

jQueryは画像の強調表示を実現します

ページ上の画像を強調表示することは非常に一般的です。ここでは、jQuery を使用して画像を強調表示...

Linux nohup コマンドの原理と例の分析

nohup コマンドUnix/Linux を使用する場合、通常はプログラムをバックグラウンドで実行す...

Django+mysql の設定と簡単な操作データベースのサンプルコード

ステップ1: MySQLドライバをダウンロードするcmdは作成されたDjangoプロジェクトディレク...

Vue.js と MJML でレスポンシブなメールを作成する

MJML は、開発者が美しく、応答性に優れ、あらゆるデバイスやメール クライアントで動作する魅力的な...

HTML ウェブページでのアンカー(名前付きアンカー)の使用の概要

以下の情報はインターネットから収集したものです1. アンカーは、Web ページ作成におけるハイパーリ...

VMware での Ubuntu と Windows 間のファイル共有

この記事では、VMware 環境下で Ubuntu と Windows 間でファイルを共有する方法を...

将来人気が出るであろういくつかのナビゲーション方向

<br />今は情報爆発の時代であるだけでなく、サービス爆発の時代でもあります。それはす...

Vue フロントエンドの Excel ファイルのエクスポートの詳細な実装計画

目次1. 技術の選択2. 技術的な実装vue-json-excelプラグインを使用して実装1. vu...

MySQL 5.5 のインストールと設定のグラフィックチュートリアル

MySQL 5.5 のインストールと構成のチュートリアル ノートを整理し、全員と共有します。 1.公...

jsはシンプルなショッピングカートモジュールを実装します

この記事の例では、参考までに、シンプルなショッピングカートモジュールを実装するためのjsの具体的なコ...

Linux カーネルプログラミングにおけるコンテナの of() 関数の紹介

序文Linux カーネルプログラミングでは、マクロ関数 container_of(ptr, type...

【HTML要素】画像の埋め込み方法

img 要素を使用すると、HTML ドキュメントに画像を埋め込むことができます。画像を埋め込むには、...

MySQL でストアド プロシージャを作成し、ループでレコードを追加する方法

この記事では、例を使用して、MySQL でストアド プロシージャを作成し、ループでレコードを追加する...

Vue ドラッグ アンド ドロップのシンプルな実装

この記事では、主に次のような Vue ドラッグ アンド ドロップの簡単な実装を紹介します。レンダリン...

VueはPCカメラを呼び出して写真機能を実現します

この記事の例では、VueがPCカメラを呼び出して写真機能を実現する具体的なコードを参考までに共有して...