この記事では、例を使用して、MySQL トリガーの概要、トリガーの作成方法、およびトリガーの使用上の制限について説明します。ご参考までに、詳細は以下の通りです。 導入 SQL トリガーは、データベース カタログに保存される一連の SQL ステートメントです。 SQL トリガーは、挿入、更新、削除など、テーブルに関連付けられたイベントが発生するたびに実行または起動されます。 SQL トリガーは、特別なタイプのストアド プロシージャと見なすこともできます。 ストアド プロシージャのように直接呼び出されないため、特別です。 トリガーとストアド プロシージャの主な違いは、トリガーはテーブルでデータ変更イベントが実行されると自動的に呼び出されるのに対し、ストアド プロシージャは明示的に呼び出す必要があることです。 次に、SQL トリガーの利点を見てみましょう。
その欠点を見てみましょう:
トリガーは特別なタイプのストアド プロシージャなので、どのように選択すればよいのでしょうか。以下は単なる提案です。ストアド プロシージャを使用して作業を完了できない場合は、SQL トリガーの使用を検討できます。 トリガーを作成する MySQL では、トリガーは、関連付けられたテーブルのデータに変更が加えられたときに自動的に呼び出される一連の SQL ステートメントです。 トリガーは、挿入、更新、または削除ステートメントによってデータが変更される前または後に呼び出されるように定義できます。 MySQL 5.7.2 より前では、テーブルごとに最大 6 つのトリガーを定義できました。彼らの簡単な紹介を見てみましょう:
ただし、MySQL 5.7.2 以降では、同じトリガー イベントとアクション時間に対して複数のトリガーを定義できます。 INSERT、DELETE、または UPDATE ステートメントを使用せずにテーブル内のデータを変更するステートメントを使用すると、テーブルに関連付けられたトリガーは呼び出されません。 たとえば、truncate ステートメントはテーブル内のすべてのデータを削除しますが、テーブルに関連付けられたトリガーは呼び出しません。ただし、REPLACE ステートメントや LOAD DATA ステートメントなど、一部のステートメントではバックグラウンド INSERT ステートメントが使用されます。これらのステートメントを使用すると、テーブルに関連付けられた対応するトリガーが呼び出されます。したがって、テーブルに関連付けられたトリガーごとに一意の名前を使用する必要があります。異なるテーブルに対して同じトリガー名を定義することをお勧めします。トリガーを定義するための構文構造を見てみましょう。 (BEFORE | AFTER)_テーブル名_(INSERT| UPDATE | DELETE) たとえば、before_order_update は、orders テーブルの行が更新される前に呼び出されるトリガーです。別の定義方法を見てみましょう。 テーブル名_(BEFORE | AFTER)_(INSERT | UPDATE | DELETE) たとえば、order_before_update は、上で説明した before_order_update トリガーと同じです。 MySQL はトリガーをデータ ディレクトリ (例: /data/luyaran/) に保存し、tablename.TRG および triggername.TRN という名前のファイルを使用します。
したがって、トリガー ファイルをバックアップ フォルダーにコピーすることで、mysql トリガーをバックアップできます。また、mysqldump ツールを使用してトリガーをバックアップすることもできます。 使用制限 MySQL トリガーは標準 SQL で定義されているすべての機能をカバーしますが、アプリケーションで使用する場合にはいくつかの制限があります。
さて、この記録についてはこれですべてです。 MySQL 関連のコンテンツに興味のある読者は、このサイトの次のトピックをチェックしてください: 「MySQL クエリ スキル」、「MySQL トランザクション操作スキル」、「MySQL ストアド プロシージャ スキル」、「MySQL データベース ロック関連スキルの概要」、および「MySQL 共通関数の概要」 この記事が皆様のMySQLデータベース設計に役立つことを願っています。 以下もご興味があるかもしれません:
|
<<: シェルスクリプトを使用して CentOS7 に python3.8 環境をインストールする (推奨)
>>: Vueカスタムツリーコントロールの使い方の詳細な説明
DataGrid コントロールの DataSource プロパティがデザイン時に設定されている場合、...
vue+element UI は Excel データをエクスポートするためのパブリック関数をカプセル...
水平スクロールはあらゆる状況に適しているわけではありませんが、適切に行えば、Web サイトを他のサイ...
前回の記事では、入力完了の簡単な検出を実現しましたが、今回はさらに一歩進んで、入力が完了した後に次の...
1つ: 1.セマンティック タグは単なる HTML であり、CSS にはセマンティクスはありません...
mysql5.7.21の簡単なインストール構成は次のとおりです。 1. MySQLのインストール1....
序文実際のビジネスでは、ページングは一般的なビジネス要件です。次に、制限クエリを使用します。制限...
この記事では、VUEの具体的なコードを共有して、下部吸引ボタンを実装する例を紹介します。具体的な内容...
整合性制約整合性制約はテーブル データの正確性を保つためのものです。データが正しくない場合は、そもそ...
上の境界線のみを表示する <table frame=above>下の境界線のみを表示する...
この記事では、参考までに、jsで書かれたシンプルなスネークゲームの具体的なコードを紹介します。具体的...
原理手ぶれ補正の原理は、イベントをトリガーすることはできますが、イベントがトリガーされてから n 秒...
1. Navicatの紹介1. Navicat とは何ですか? Navicat は強力な MySQ...
目次MySQLの大文字と小文字の区別はパラメータによって制御されますMySQLの大文字と小文字の区別...
目次序文1. モナドの判断1.1 例1.2 オブジェクトに入れる1.3 マップに載せる2. 複数の判...