MySQLはトリガーを使用してデータベース内のテーブルの行制限を解決します。詳細な説明と例 最近のプロジェクト要件では、操作ログの数を 10 万件に制限しています。10 万件を超える場合は、最も古いログが削除され、データベースに保存されるログの数は 10 万件を超えません。 区切り文字 $ トリガー 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 $ 区切り文字 ; 実証された有効性 読んでいただきありがとうございます。お役に立てれば幸いです。このサイトをサポートしていただきありがとうございます。 以下もご興味があるかもしれません:
|
<<: Nginx 仮想ホスト (IP ベース) を構成する 3 つの方法の詳細な説明
>>: Vue で親子コンポーネントの値を双方向バインドするために v-model を使用するときに発生する問題と解決策
目次1. シナリオ2. 基盤となるAPIを簡素化する2.1 自動的に破棄を呼び出す2.2 VM値を作...
1. 外部CSSファイルの基本スタイルをインポートする<link> タグを使用して外部ス...
序文ActiveMQ は、Apache が開発した最も人気があり強力なオープン ソース メッセージ ...
目次序文1. Mixin とは何ですか? 2. Mixin はいつ使用すればよいですか? 3. Mi...
この記事は、参考のためにMySQL 8.0.17のインストールと設定のグラフィックチュートリアルを記...
Vm 内のハイパーリンク URL は、Get 要求のパラメータとして中国語と連結する必要があります。...
Docker Compose は、Docker コンテナ クラスターのオーケストレーションを実現しま...
ほとんどのブラウザはデフォルトで入力値をキャッシュし、ctl+F5 を使用して強制的に更新することに...
序文決まり文句です。ここでは、フロントエンドとバックエンドの分離についての私の理解についてお話ししま...
Linux システムの bash history コマンドは、以前に実行したコマンドを記憶し、再入力...
CentOS公式サイトアドレスhttps://www.centos.org/まず必要なファイルをダウ...
まず、action はフォームの属性です。HTML5 では必須の属性値として定義されています。onS...
目次1. 理解2. 使用1. h() パラメータ2. 使い方が簡単3. カウンターケースを実装する4...
以下のように表示されます。名前説明する文字可変(n)、varchar(n)長さ制限あり、可変長文字(...
序文Linux サーバーを操作および管理するときに、最もよく使用されるコマンドの 1 つが nets...