別のテーブルに行を挿入する MySQL トリガーをプログラムする方法
概要:
MySQL トリガーは、データベース イベントに応じたアクションを自動化する強力なメカニズムです。トリガーされるアクションには、他のテーブルへの行の挿入が含まれる場合があります。これは、データの一貫性を維持するときによく必要となります。この記事では、特定のイベント時に別のテーブルに行を挿入する MySQL トリガーを作成するプロセスについて説明します。
LAST_INSERT_ID() およびデータ ストレージ:
ストアド プロシージャの使用:
基本的なトリガー構造:
以下は、挿入する MySQL トリガーの基本構造です。別のテーブルへの行の追加:
CREATE TRIGGER trigger_name AFTER/BEFORE INSERT/UPDATE/DELETE ON table_name FOR EACH ROW BEGIN -- Insert rows into another table using data from the last inserted row. INSERT INTO other_table (column1, column2, ...) VALUES (new.column1, new.column2, ...); END
実装例:
コメントとアクティビティという 2 つのテーブルがあるとします。新しいコメントがコメント テーブルに挿入されると、コメント ID とユーザー ID をアクティビティ テーブルに記録する必要があります。対応するトリガーは次のとおりです:
CREATE TRIGGER comments_after_ins_trig AFTER INSERT ON comments FOR EACH ROW BEGIN DECLARE activity_id INT; DECLARE user_id INT; SET activity_id = LAST_INSERT_ID(); SET user_id = NEW.user_id; INSERT INTO activities (comment_id, user_id) VALUES (activity_id, user_id); END
結論:
これらの手順に従うことで、特定のイベントに基づいて別のテーブルに行を自動的に挿入するように MySQL トリガーをプログラムできます。この手法は、データの一貫性を維持し、複雑なデータ処理操作を実装するために非常に重要です。
以上が別のテーブルにデータを挿入する MySQL トリガーを作成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。