MySQL トリガーの紹介、トリガーの作成、使用制限の分析

MySQL トリガーの紹介、トリガーの作成、使用制限の分析

この記事では、例を使用して、MySQL トリガーの概要、トリガーの作成方法、およびトリガーの使用上の制限について説明します。ご参考までに、詳細は以下の通りです。

導入

SQL トリガーは、データベース カタログに保存される一連の SQL ステートメントです。 SQL トリガーは、挿入、更新、削除など、テーブルに関連付けられたイベントが発生するたびに実行または起動されます。 SQL トリガーは、特別なタイプのストアド プロシージャと見なすこともできます。 ストアド プロシージャのように直接呼び出されないため、特別です。 トリガーとストアド プロシージャの主な違いは、トリガーはテーブルでデータ変更イベントが実行されると自動的に呼び出されるのに対し、ストアド プロシージャは明示的に呼び出す必要があることです。

次に、SQL トリガーの利点を見てみましょう。

  • SQL トリガーは、データの整合性をチェックする代替方法を提供します。
  • SQL トリガーは、データベース層のビジネス ロジックのエラーをキャッチできます。
  • SQL トリガーは、スケジュールされたタスクを実行する別の方法を提供します。 SQL トリガーを使用すると、テーブル内のデータに変更が加えられる前または後にトリガーが自動的に呼び出されるため、スケジュールされたタスクの実行を待つ必要がなくなります。
  • SQL トリガーは、テーブル内のデータの変更を監査するのに非常に便利です。

その欠点を見てみましょう:

  • SQL トリガーは拡張検証のみを提供でき、すべての検証を置き換えることはできません。アプリケーション層でいくつかの簡単な検証を実行する必要があります。 たとえば、JavaScript を使用してクライアント側でユーザー入力を検証したり、JSP、PHP、ASP.NET、Perl などのサーバー側スクリプト言語を使用してサーバー側でユーザー入力を検証したりできます。
  • クライアント アプリケーションからの SQL トリガーの呼び出しと実行は表示されないため、データベース層で何が起こっているかを把握するのは困難です。
  • SQL トリガーはデータベース サーバーにオーバーヘッドを追加する可能性があります。

トリガーは特別なタイプのストアド プロシージャなので、どのように選択すればよいのでしょうか。以下は単なる提案です。ストアド プロシージャを使用して作業を完了できない場合は、SQL トリガーの使用を検討できます。

トリガーを作成する

MySQL では、トリガーは、関連付けられたテーブルのデータに変更が加えられたときに自動的に呼び出される一連の SQL ステートメントです。 トリガーは、挿入、更新、または削除ステートメントによってデータが変更される前または後に呼び出されるように定義できます。 MySQL 5.7.2 より前では、テーブルごとに最大 6 つのトリガーを定義できました。彼らの簡単な紹介を見てみましょう:

  • BEFORE INSERT − トリガーはデータがテーブルに挿入される前にアクティブ化されます。
  • AFTER INSERT − データがテーブルに挿入された後にトリガーをアクティブにします。
  • BEFORE UPDATE − テーブル内のデータが更新される前にトリガーをアクティブにします。
  • AFTER UPDATE − テーブル内のデータが更新された後にトリガーをアクティブにします。
  • BEFORE DELETE − テーブルからデータが削除される前にトリガーがアクティブ化されます。
  • AFTER DELETE − テーブルからデータが削除された後にトリガーがアクティブになります。

ただし、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 という名前のファイルを使用します。

  • tablename.TRG ファイルは、トリガーを対応するテーブルにマップします。
  • triggername.TRN ファイルにはトリガー定義が含まれています。

したがって、トリガー ファイルをバックアップ フォルダーにコピーすることで、mysql トリガーをバックアップできます。また、mysqldump ツールを使用してトリガーをバックアップすることもできます。

使用制限

MySQL トリガーは標準 SQL で定義されているすべての機能をカバーしますが、アプリケーションで使用する場合にはいくつかの制限があります。

  • SHOW、LOAD DATA、LOAD TABLE、BACKUP DATABASE、RESTORE、FLUSH、および RETURN ステートメントで使用されます。
  • COMMIT、ROLLBACK、START TRANSACTION、LOCK/UNLOCK TABLES、ALTER、CREATE、DROP、RENAME など、暗黙的または明示的にコミットまたはロールバックするステートメントを使用します。
  • PREPARE、EXECUTE などの準備済みステートメントを使用します。
  • 動的 SQL ステートメントを使用します。

さて、この記録についてはこれですべてです。

MySQL 関連のコンテンツに興味のある読者は、このサイトの次のトピックをチェックしてください: 「MySQL クエリ スキル」、「MySQL トランザクション操作スキル」、「MySQL ストアド プロシージャ スキル」、「MySQL データベース ロック関連スキルの概要」、および「MySQL 共通関数の概要」

この記事が皆様のMySQLデータベース設計に役立つことを願っています。

以下もご興味があるかもしれません:
  • MySQL トリガー構文とアプリケーション例
  • MySql ビュー トリガー ストアド プロシージャの詳細な説明
  • MySQL トリガーの原理と使用例の分析
  • MySQL ログトリガー実装コード
  • MySQL トリガーの追加、削除、変更、クエリ操作の例
  • MySQL トリガー: 複数のトリガー操作の作成例の分析
  • MySQL トリガー: トリガーの作成と使用
  • MySQL トリガーの定義と使用方法の簡単な例
  • MySQLトリガーの概念、原理、使用法の詳細な説明
  • MySQL でトリガーを無効化および有効化するチュートリアル [推奨]
  • MySQLデータベーストリガーの詳細な説明

<<:  シェルスクリプトを使用して CentOS7 に python3.8 環境をインストールする (推奨)

>>:  Vueカスタムツリーコントロールの使い方の詳細な説明

ブログ    

推薦する

JS 関数のアンチシェイクと関数スロットリングを理解する方法

目次概要1. 関数デバウンス2. 機能スロットリング(スロットル)概要関数アンチシェイクと関数スロッ...

CSSで検索ボックスを非表示にする機能を実装します(アニメーション順方向と逆方向のシーケンス)

上部のメニュー バーに検索ボックスを配置するのは一般的なシナリオですが、検索機能がそれほど頻繁に使用...

JavaScriptの動作原理を理解しましょう

目次ブラウザカーネルJavaScript エンジンV8エンジンJavaScript がどのように実行...

クリーンで美しいウェブデザインのための4つの原則

この記事では、 Webデザインに関連するこれら4 つの原則について説明します。これら4 つの原則を念...

vue+element-uiはヘッドナビゲーションバーコンポーネントを実装します

この記事では、vue+element-uiでヘッドナビゲーションバーコンポーネントを実装するための具...

ECMAScriptにおけるプリミティブ値と参照値の詳しい説明

目次序文動的プロパティとは何ですか?値のコピー値の種類を決定する要約する序文これは JavaScri...

Ubuntu 18.04 に mysql5.7.23 をインストールするチュートリアル

この記事では、Ubuntu18.04にmysql5.7.23をインストールする具体的な方法を参考まで...

ホバープロンプトにはvue2+elementuiを使用する

Vue2+elementui のホバー プロンプトは、外部と内部に分かれています。内部のものは el...

Nginx のパフォーマンスを向上させるための提案

Web アプリケーションが 1 台のマシンでのみ実行される場合、パフォーマンスを向上させるのは非常に...

クラウド サーバーを使用して CentOS システムに .NET 6.0 をインストールする

.NET SDK ダウンロード リンクhttps://dotnet.microsoft.com/do...

Reactは二次的連鎖効果(階段効果)を実現する

この記事では、二次リンク効果を実現するためのReactの具体的なコードを参考までに共有します。具体的...

Windows ベースの MySQL 8.0.12 のインストール

このチュートリアルは Windows システムにのみ適用されます。インストールしたがまだインストール...

VMware マルチノード環境を構成する方法

このチュートリアルでは CentOS 7 64 ビットを使用します。各仮想マシンに 2GB のメモリ...

フォームのデフォルトの送信方法を変更する方法

htmlのデフォルトの送信方法は、postではなくgetです。postに変更したい場合は、 meth...

LINUX ポートが占有されているかどうかを確認します

ポートが占有されているかどうかは、これまで一度もわかりませんでした。多くの人に尋ねて、ようやくわかり...