この記事では、MySQL トリガーの定義と使用方法について説明します。ご参考までに、詳細は以下の通りです。 文法 CREATE TRIGGER トリガー名- トリガーには、最大 64 文字の名前が必要です。名前の後に区切り文字を続けることもできます。名前は、MySQL の他のオブジェクトとほぼ同じように付けられます。 例の準備 -- テーブル 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データベース設計に役立つことを願っています。 以下もご興味があるかもしれません:
|
<<: nginx httpモジュールのデータ保存構造の概要
>>: 一般的なテーブルコンポーネントの Vue カプセル化の完全な手順記録
1. まずMySqlの公式サイトからダウンロードします参考: https://www.jb51.ne...
今日、最終プロジェクトに取り組み始めましたが、今年はMySQLデータベースを使用したため、Navic...
CPU 負荷と CPU 使用率これらは両方とも、ある程度、マシンの忙しさを反映できます。 CPU 使...
PostgreSQL はコンパイルされインストールされるため、起動時に起動するように設定する必要があ...
この記事では、無限ループスクロールを実現するためのReactの具体的なコードを参考までに紹介します。...
この記事では、例を使用して、MySQL データベースの基本的な知識と操作について説明します。ご参考ま...
序文プロジェクトを .net core に移行した後、 System.Drawing.Commonコ...
文法 背景: linear-gradient(direction,color-stop1,color...
トランザクション分離レベルの設定 グローバルトランザクション分離レベルを読み取りコミット済みに設定;...
この記事では、アコーディオン効果を実現するためのjsの具体的なコードを参考までに共有します。具体的な...
プロジェクトの展開中に遭遇した落とし穴Zhihudemo を展開する際、Jenkins などの自動展...
関連記事:初心者が学ぶ HTML タグ (5)導入された HTML タグは、必ずしも XHTML 仕...
メディアデバイスタイプの使用法の詳細な説明: <!DOCTYPE html> <h...
目次1. 概要2. dockerを使用してTomcatをデプロイし、Skywalkingに接続する要...
1.コマンドが見つかりません コマンドが見つかりません2. そのようなファイルまたはディレクトリは...