イベント通知のデザイン

更新 : 2006 年 4 月 14 日

イベント通知をデザインするには、次の項目を特定する必要があります。

  • 通知スコープ。
  • イベント通知を発生させる Transact-SQL ステートメントまたはステートメントのグループ。

通知スコープの定義

イベント通知は、現在のデータベース内のすべてのオブジェクトまたは SQL Server の 1 つのインスタンスにあるすべてのオブジェクトで作成されたステートメントに応答して発生させるように指定できます。QUEUE_ACTIVATION イベントと BROKER_QUEUE_DISABLED イベントで指定されたイベント通知は、個別のキューにスコープが設定されます。すべてのイベントを任意のスコープで発生させることができるわけではありません。たとえば、CREATE_DATABASE イベントはサーバー インスタンス レベルでのみ発生させることができます。逆に、ALTER_TABLE イベントで作成されるイベント通知は、データベース内のすべてのテーブルまたはサーバー インスタンスのすべてのテーブルで発生するようにプログラミングできます。

次の例では、サーバー インスタンスで実行される任意の ALTER TABLE ステートメントの通知を現在のデータベースの Service Broker インスタンスに送信します。

CREATE EVENT NOTIFICATION log_ddl1 
   ON SERVER 
   FOR ALTER_TABLE 
   TO SERVICE '//Adventure-Works.com/ArchiveService' , 'current database';

Transact-SQL ステートメントと、そのステートメントに指定できるスコープへのリンクについては、後述の「イベント通知を発生させる特定の DDL ステートメントの選択」で説明します。

イベント通知は、ローカルまたはグローバルの一時テーブル、およびストアド プロシージャに影響するイベントへの応答として発生することはありません。

Transact-SQL ステートメントまたはステートメントのグループの指定

イベント通知は、次の項目に応答して発生するように作成できます。

  • 特定の DDL ステートメント、SQL トレース イベント、または Service Broker イベント
  • DDL ステートメントまたは SQL トレース イベントの定義済みグループ

イベント通知を発生させる特定の DDL ステートメントの選択

イベント通知は、特定の Transact-SQL ステートメントまたはストアド プロシージャの実行後に発生するように設計できます。上記の例で示したように、イベント通知は ALTER_TABLE イベントの後に発生します。

イベント通知を発生させることができる個々の Transact-SQL ステートメントおよび通知を実行できるスコープの一覧は、「イベント通知で使用する DDL イベント」に記載されています。また、これらのイベントは、sys.event_notification_event_types カタログ ビューにクエリを実行することでも取得できます。

ms175854.note(ja-jp,SQL.90).gifメモ :
DDL と同様の操作を実行する特定のシステム ストアド プロシージャもイベント通知を起動できます。イベント通知はテストして、実行されているシステム ストアド プロシージャに応答するかどうか、確認してください。たとえば、CREATE TYPE ステートメントおよび sp_addtype ストアド プロシージャはどちらも、CREATE_TYPE イベントで作成されるイベント通知を起動します。一方、sp_rename ストアド プロシージャは、どのイベント通知も起動しません。

イベント通知を発生させる特定の SQL トレース イベントの選択

イベント通知は、SQL Trace イベントの発生後に実行されるようにデザインできます。たとえば、次のイベント通知はサーバーでの Object_Created イベントの後に発生します。

CREATE EVENT NOTIFICATION log_ddl1 
   ON SERVER 
   FOR Object_Created 
   TO SERVICE '//Adventure-Works.com/ArchiveService', 'current database' ;

イベント通知を発生させることができる SQL トレース イベントの一覧については、「イベント通知で使用するトレース イベント」を参照してください。また、これらのイベントの一覧は、sys.event_notification_event_types カタログ ビューにクエリを実行することでも取得できます。SQL トレース イベントは、サーバー インスタンスのスコープでのみ実行できます。SQL トレース イベント クラスの詳細については、「SQL Server Profiler のリファレンス」を参照してください。

イベント通知を発生させる Service Broker イベントの選択

イベント通知は、Service Broker イベントである QUEUE_ACTIVATION または BROKER_QUEUE_DISABLED の後に発生するようにデザインできます。QUEUE_ACTIVATION イベントは、キューに処理するメッセージが登録されたときに発生します。詳細については、「イベントベースのアクティブ化」を参照してください。BROKER_QUEUE_DISABLED イベントは、キューの状態が OFF に設定されたときに発生します。詳細については、「有害なメッセージの処理」を参照してください。

イベント通知を発生させる DDL ステートメントの定義済みグループの選択

イベント通知は、同様のイベントの定義済みグループに属する任意の Transact-SQL イベントの実行後に発生させることができます。たとえば、任意の CREATE TABLE ステートメント、ALTER TABLE ステートメント、または DROP TABLE ステートメントの実行後にイベント通知を発生させる場合、CREATE EVENT NOTIFICATION ステートメントで FOR DDL_TABLE_EVENTS を指定できます。CREATE EVENT NOTIFICATION の実行後、イベント グループに含まれるイベントが sys.events カタログ ビューに追加されます。

イベント通知に使用できる DDL ステートメントと DML ステートメントの定義済みグループの一覧、それらのグループに含まれる特定のステートメント、およびこれらのイベント グループを実行できるスコープについては、「イベント通知の実行に使用できる DDL イベント グループ」を参照してください。

イベント通知を発生させる SQL トレース イベントの定義済みグループの選択

イベント通知は、同様のトレース イベントの定義済みグループに属する任意の SQL トレース イベントの実行後に発生させることができます。たとえば、LOCK_DEADLOCK、LOCK_DEADLOCK_CHAIN、LOCK_ESCALATION、および DEADLOCK_GRAPH イベントなど、ロック関連の任意のトレース イベントの実行後にイベント通知を発生させる場合、CREATE EVENT NOTIFICATION ステートメントで FOR TRC_LOCKS を指定できます。

イベント通知で使用可能な定義済みの SQL トレース イベントのグループの一覧については、「イベント通知の実行に使用できるトレース イベント グループ」を参照してください。これらのグループは、サーバー インスタンス レベルでのみ実行できます。

参照

概念

イベント通知について
イベント通知の実装

その他の技術情報

EVENTDATA (Transact-SQL)

ヘルプおよび情報

SQL Server 2005 の参考資料の入手

変更履歴

リリース 履歴

2006 年 4 月 14 日

新しい内容 :
  • 実行されているストアド プロシージャへの応答に対するイベント通知をテストすることを推奨する注を追加しました。
  • sys.event_notification_event_types カタログ ビューについてのリファレンスを追加しました。

2005 年 12 月 5 日

変更内容 :
  • 「イベント通知を発生させる特定の DDL ステートメントの選択」に、特定のストアド プロシージャの実行後に発生させることができるイベント通知についての情報を追加しました。