MySQL トリガーの定義と使用方法の簡単な例

MySQL トリガーの定義と使用方法の簡単な例

この記事では、MySQL トリガーの定義と使用方法について説明します。ご参考までに、詳細は以下の通りです。

文法

CREATE TRIGGER トリガー名- トリガーには、最大 64 文字の名前が必要です。名前の後に区切り文字を続けることもできます。名前は、MySQL の他のオブジェクトとほぼ同じように付けられます。
{ BEFORE | AFTER } -- トリガーには実行時間設定があり、イベント発生前または発生後に設定できます。
{ INSERT | UPDATE | DELETE } -- トリガーするイベントを設定することもできます。挿入、更新、または削除の実行中にトリガーできます。
ON テーブル名- トリガーは特定のテーブルに属します。このテーブルで挿入、更新、または削除操作が実行されると、トリガーがアクティブになります。同じテーブル上の同じイベントに 2 つのトリガーを割り当てることはできません。
FOR EACH ROW -- トリガー実行間隔: FOR EACH ROW 句は、トリガーに対して、テーブル全体に対して 1 回ではなく、1 行おきにアクションを実行するように指示します。
<トリガー SQL ステートメント> -- トリガーには、トリガーされる SQL ステートメントが含まれます。ここでのステ​​ートメントは、複合ステートメントを含む任意の有効なステートメントにすることができますが、ここでのステ​​ートメントの制限は関数の場合と同じです。

例の準備

-- テーブル tab1 を作成する
tab1が存在する場合はテーブルを削除します。
テーブルを作成 tab1(
  tab1_id varchar(11)
);
-- テーブル tab2 を作成する
tab2が存在する場合はテーブルを削除します。
テーブル tab2 を作成します (
  tab2_id varchar(11)
);

例1: 新しいエントリを追加すると、別のテーブルが追加されます

-- トリガーを作成: t_afterinsert_on_tab1
-- 効果: tab1 テーブルにレコードを追加した後、tab2 テーブルにレコードを自動的に追加します。DROP TRIGGER IF EXISTS t_afterinsert_on_tab1;
トリガー t_afterinsert_on_tab1 を作成する
タブ1に挿入後
各行ごとに
始める
   tab2(tab2_id) に値(new.tab1_id) を挿入します。
終わり;
-- テスト INSERT INTO tab1(tab1_id) values('0001');
-- 結果を確認します SELECT * FROM tab1;
タブ2から*を選択

例 2: 1 つのエントリを削除すると、別のテーブルも削除される

-- トリガーを作成: t_afterdelete_on_tab1
-- 効果: tab1 テーブルのレコードを削除すると、tab2 テーブルの対応するレコードが自動的に削除されます。DROP TRIGGER IF EXISTS t_afterdelete_on_tab1;
トリガー t_afterdelete_on_tab1 を作成する
タブ1の削除後
各行ごとに
始める
   tab2_id=old.tab1_id の tab2 から削除します。
終わり;
-- テスト DELETE FROM tab1 WHERE tab1_id='0001';
-- 結果を確認します SELECT * FROM tab1;
tab2から*を選択します。

例3: 1つの行を更新して別のテーブルの更新をトリガーする

-- トリガーを作成: t_afterupdate_on_tab1
-- 効果: tab1 テーブルのレコードを変更した後、tab2 テーブルの対応するレコードを自動的に更新します。DROP TRIGGER IF EXISTS t_afterupdate_on_tab1;
トリガー t_afterupdate_on_tab1 を作成する
tab1 の更新後
各行ごとに
始める
   tab2 を更新します。tab2_id=new.tab1_id を設定します。tab2_id=old.tab1_id;
終わり;
-- テスト更新 tab1 set tab1_id='0002' WHERE tab1_id='0001';
-- 結果を確認します SELECT * FROM tab1;
tab2から*を選択します。

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

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

以下もご興味があるかもしれません:
  • MySQL トリガーの使用シナリオとメソッドの例
  • MySQL トリガーの原理と使用例の分析
  • MySQL トリガー: 複数のトリガー操作の作成例の分析
  • MySQLトリガーの使用例の詳細
  • MySQLはトリガーを使用してデータベース内のテーブルの行制限を解決します。詳細な説明と例
  • MySQLトリガーの詳細な説明と簡単な例
  • MySQL トリガーを使用してデータを移行および同期するサンプル チュートリアル
  • MySQLトリガーの簡単な概要と例
  • MySQLトリガーの簡単な例と紹介
  • MySQLトリガーの例の詳細な説明

<<:  nginx httpモジュールのデータ保存構造の概要

>>:  一般的なテーブルコンポーネントの Vue カプセル化の完全な手順記録

推薦する

MySql 5.7.20 のインストールとデータおよび my.ini ファイルの構成

1. まずMySqlの公式サイトからダウンロードします参考: https://www.jb51.ne...

Navicat PremiumでSQLファイルをインポートする方法

今日、最終プロジェクトに取り組み始めましたが、今年はMySQLデータベースを使用したため、Navic...

LinuxのCPU負荷とCPU使用率の詳細な説明

CPU 負荷と CPU 使用率これらは両方とも、ある程度、マシンの忙しさを反映できます。 CPU 使...

Ubuntu 16.04 で PostgreSQL の起動を設定する方法

PostgreSQL はコンパイルされインストールされるため、起動時に起動するように設定する必要があ...

Reactは無限ループスクロール情報を実装する

この記事では、無限ループスクロールを実現するためのReactの具体的なコードを参考までに紹介します。...

MySQLデータベースの基礎知識と操作のまとめ

この記事では、例を使用して、MySQL データベースの基本的な知識と操作について説明します。ご参考ま...

Linux/Docker で System.Drawing.Common を使用する

序文プロジェクトを .net core に移行した後、 System.Drawing.Commonコ...

CSS コンテナ背景 10 色グラデーション デモ (linear-gradient())

文法 背景: linear-gradient(direction,color-stop1,color...

MySQL マルチバージョン同時実行制御 MVCC の実装

トランザクション分離レベルの設定 グローバルトランザクション分離レベルを読み取りコミット済みに設定;...

シンプルなアコーディオン効果を実現するjs

この記事では、アコーディオン効果を実現するためのjsの具体的なコードを参考までに共有します。具体的な...

CentOS7 で jar アプリケーションの起動を設定する方法

プロジェクトの展開中に遭遇した落とし穴Zhihudemo を展開する際、Jenkins などの自動展...

HTML チュートリアル: よく使われる HTML タグのコレクション (6)

関連記事:初心者が学ぶ HTML タグ (5)導入された HTML タグは、必ずしも XHTML 仕...

dockerを使用してTomcatをデプロイし、Skywalkingに接続する

目次1. 概要2. dockerを使用してTomcatをデプロイし、Skywalkingに接続する要...

よくある Linux 英語エラーの中国語翻訳 (初心者必見)

1.コマンドが見つかりません コマンドが見つかりません2. そのようなファイルまたはディレクトリは...