トリガーにより、ステートメントの実行前または実行後に他の SQL コードを実行できます。トリガーは、トリガー ステートメントによって変更されたデータを読み取ることができますが、戻り値はありません。したがって、トリガーを使用すると、アプリケーション内に対応するコードを記述せずに、ビジネス ロジックの制約を適用できます。 上記の説明から、トリガーを使用するとアプリケーションのロジックが簡素化され、パフォーマンスが向上することがわかります。これは、トリガーを使用すると、アプリケーションとサーバー間のやり取りの回数が減るためです。また、トリガーは正規化と統計を自動的に更新するのに役立ちます。たとえば、トリガーを使用して、合計取引金額、注文数、平均注文値を自動的にカウントできます。 ただし、MySQL トリガーの適用シナリオも非常に限られています。他のデータベース製品のトリガーを使用したことがある場合は、MySQL でも同じ機能を実現できるとは想定しないでください。例:
CREATE TRIGGER トリガー名 BEFORE | AFTER トリガーイベント ON テーブル名 FOR EACH ROW 始める ステートメントリストを実行します。 終わり 実行ステートメント リストは、単一または複数のステートメントをサポートします。次に、複数のステートメントの例を示します。 区切り文字 $$ 各行に対して t_users に INSERT した後に、トリガー user_create_log を作成します。 始める log_info VARCHAR(40) 文字セット utf8 を宣言します。 DECLARE description VARCHAR(20) character set utf8;#後に中国語の文字エンコードが文字化けしていることが判明したので、ここで文字セットを設定しました SET description = " が作成されます"; SET log_info = CONCAT(NEW.user_name, description); #CONCAT 関数は文字列を連結できます INSERT INTO logs(log) values(log_info); 終了 $$ 区切り文字 ;
最も大きな制限は FOR EACH ROW の設計です。これにより、トリガーを使用して統計やキャッシュ テーブルを維持できなくなることがあります。これは、処理が遅くなる可能性があるためです。トリガーを使用する主な理由は、スケジュールされた同期更新と比較して、データの一貫性を一貫して維持できることです。 トリガーもアトミック性を保証することはできません。たとえば、MyISAM テーブルを更新するトリガーは、ソース SQL ステートメントでエラーが発生した場合はロールバックできません。さらに、トリガー自体に欠陥がある可能性もあります。 MyISAM データ テーブルに基づいて AFTER UPDATE を使用して別のテーブルを更新する場合。トリガーにエラーがあり、2 番目のテーブルでの操作が失敗した場合、最初のテーブルでの操作はロールバックされません。 ソース ステートメントを含む InnoDB トリガー関連の操作はすべて同じトランザクション内にあるため、アトミック性要件を満たしています。ただし、InnoDB トリガーを使用して別のテーブルとのデータの一貫性を検証する場合、注意しないと誤った結果が生じる可能性があります。たとえば、トリガーを使用して外部キーをシミュレートする必要がある場合は、BEFORE INSERT トリガーを使用して、対応するレコードが別のテーブルに存在するかどうかを確認できます。ただし、トリガーが別のテーブルからデータを読み取るときに SELECT FOR UPDATE を使用しないと、同時実行の問題により誤った結果が発生する可能性があります。 トリガーにはいくつか欠陥がありますが、使用できないわけではありません。逆に、トリガーは、特に制約、システム メンテナンス タスク、統計を最新の状態に保つ場合など、それ自体でも役立ちます。 トリガーを使用してデータ行の変更を記録することもできます。この方法では、オフラインでの手動データベース操作(誤ったデータの修復など)の記録も記録できます。ただし、他の自動インクリメント主キー テーブルにデータを挿入する場合は注意が必要です。2 つの同一のレプリカの自動インクリメント値が異なるため、複製されたステートメントで問題が発生する可能性があります。 結論: トリガーは、統計データ、データ テーブルの変更ログなどの限られた状況でその利点を発揮できます。ただし、いくつかの欠点もあります。たとえば、大量のデータを更新すると、行ごとにトリガーされるため、効率が低下します。また、MyISAM エンジンはアトミック性を保証できません。したがって、トリガーがあるかどうかは、アプリケーション シナリオによって異なります。 以上がMySQLトリガーの使用に関する詳細な内容です。MySQLトリガーの詳細については、123WORDPRESS.COMの他の関連記事にも注目してください。 以下もご興味があるかもしれません:
|
>>: Tomcat ソースコード起動コンソールの中国語文字化けのデバッグプロセス記録
1. 問題の症状バージョン: MySQL 5.6、従来の binlog ファイルと pos 方式を使...
最近の Web サイトでは Https をサポートすることがほぼ標準機能となっており、Nginx は...
目次事前準備展開ターゲットDocker環境構築クラウドサーバーに接続Docker環境をインストールす...
場合によっては、ベースイメージに特定の依存関係をインストールする必要があります。Dockerfile...
序文:前回の記事では、MySQL システムでよく使用されるログをいくつか説明しました。実は、トランザ...
MySQL テーブルでの接続方法は実は非常に簡単なので、ここではその特徴を簡単にリストします。テーブ...
通常の開発では、凸型の丸い角、つまり border-radius 属性を使用するのが一般的です。凹角...
mysql ストレージ エンジン: MySQL サーバーはモジュール スタイルを採用しており、特にス...
目次1. 概要2. メモリ管理3. ガベージコレクション4. GCアルゴリズムの紹介5. 参照カウン...
Linuxファイルを表示する方法ファイルの内容を表示するコマンド: catは最初の行からコンテンツを...
目次序文: 1. データ移行について2. 移行計画と留意点要約:序文:日常業務では、テーブル、データ...
mysql は期間内のすべての日付または月を取得します1: mysqlは期間内のすべての月を取得し...
Vue プロジェクトで mock.js を使用する開発ツールの選択: Vscode 1. コマンドラ...
豊富なオプションを備えた強力なエディターとして、Vim は多くのユーザーに愛されています。この記事で...
目次質問サーバー層とストレージエンジン層LIMITって何ですか?何をするか?トゥカオ最近、Q&...