最初と最後のトリガーの指定
適用対象:SQL ServerAzure SQL DatabaseAzure SQL Managed Instance
テーブルに関連付けられている AFTER トリガーの 1 つを、INSERT、DELETE、および UPDATE の各トリガー動作に対して起動される、最初の AFTER トリガーまたは最後の AFTER トリガーのいずれかに指定できます。 最初と最後のトリガーの間で起動される AFTER トリガーは、任意の順序で実行されます。
AFTER トリガーの順序を指定するには、 sp_settriggerorder ストアド プロシージャを使用します。 sp_settriggerorder には次のオプションがあります。
オプション | 説明 |
---|---|
先頭 | DML トリガーが、トリガー動作に対して起動される最初の AFTER トリガーであることを指定します。 |
最新 | DML トリガーが、トリガー動作に対して起動される最後の AFTER トリガーであることを指定します。 |
なし | DML トリガーを起動する特定の順番がないことを指定します。 主に最初または最後のトリガーのいずれかの順序をリセットするときに使用します。 |
次の例は、 sp_settriggerorderを使用する例を示しています。
sp_settriggerorder @triggername = 'MyTrigger', @order = 'first', @stmttype = 'UPDATE'
重要
最初のトリガーと最後のトリガーは、2 つの異なる DML トリガーである必要があります。
テーブルでは、INSERT、UPDATE、および DELETE の各トリガーを同時に定義することができます。 各ステートメントはその型ごとに、固有の最初と最後のトリガーを持つことができますが、最初と最後に同じトリガーを持つことはできません。
1 つのテーブルに定義された最初のトリガーまたは最後のトリガーが、FOR UPDATE、FOR DELETE、または FOR INSERT などのトリガー動作に対応していない場合は、それらの動作に対する最初のトリガーまたは最後のトリガーを設定できません。
INSTEAD OF トリガーは最初のトリガーまたは最後のトリガーとして指定できません。 INSTEAD OF トリガーは基になるテーブルが更新される前に起動されるためです。 INSTEAD OF トリガーによって基になるテーブルが更新された場合、テーブルで定義された AFTER トリガーが起動される前に更新が発生します。 たとえば、ビュー上の INSTEAD OF INSERT トリガーによってベース テーブルにデータが挿入され、ベース テーブル自体に INSTEAD OF INSERT トリガーおよび 3 つの AFTER INSERT トリガーが含まれる場合、挿入操作の代わりに、ベース テーブルにある INSTEAD OF INSERT トリガーが起動されます。また、ベース テーブルでの挿入操作の後、ベース テーブルにある AFTER トリガーが起動されます。 詳しくは、「 DML Triggers」をご覧ください。
ALTER TRIGGER ステートメントによって最初のトリガーまたは最後のトリガーが変更された場合、 First 属性または Last 属性が削除され、順序の値が Noneに設定されます。 sp_settriggerorderを使用して順序をリセットする必要があります。
OBJECTPROPERTY 関数は、次のプロパティを使用して、トリガーが最初のトリガーか最後のトリガーかを報告します。 ExecIsFirstInsertTrigger、 ExecIsFirstUpdateTrigger、 execIsFirstDeleteTrigger、ExecIsLastInsertTrigger、ExecIsLastUpdateTrigger、および ExecIsLastDeleteTrigger。
レプリケーションは、テーブルが即時更新サブスクリプションまたはキュー更新サブスクリプションに含まれる場合、自動的に最初のトリガーを生成します。 レプリケーションのトリガーは最初のトリガーであることが必要です。 レプリケーションでは、最初のトリガーを持つテーブルを即時更新サブスクリプションまたはキュー更新サブスクリプションに含めるよう設定すると、エラーが発生します。 テーブルをサブスクリプションに含めた後、トリガーを最初のトリガーに設定すると、 sp_settriggerorder はエラーを返します。 レプリケーション トリガーに ALTER を使用したり、 sp_settriggerorder を使用してレプリケーション トリガーを最後のトリガーまたは順序なしのトリガーに変更すると、サブスクリプションは正しく動作しません。
参照
OBJECTPROPERTY (Transact-SQL)
sp_settriggerorder (Transact-SQL)