サブスクリプションと配信 (Reporting Services)

Reporting Services サブスクリプションは、特定の時刻に、またはイベントに応答して、レポートを配信する構成です。 指定したファイル形式にもあります。 たとえば、毎週水曜日に、MonthlySales.rdl レポートを Microsoft Word 文書としてファイル共有に保存します。 サブスクリプションを使用して、レポート配信のスケジュールや自動化を設定したり、レポート パラメーターの特定の値セットを指定したりすることができます。

ひとつのレポートに対して複数のサブスクリプションを作成して、サブスクリプション オプションを変更できます。 たとえば、異なるパラメーター値を指定して、3 つのバージョンのレポートの生成ができます。 これらは、西部地域の売上レポート、東部地域の売上、すべての売上などのレポートです。

Diagram of an example SSRS subscription flow.

サブスクリプションは、SQL Serverのすべてのエディションで使用できるわけではありません。 SQL Server がサポートする機能の一覧については、「SQL Server 2022 の各エディションとサポートされている機能」を参照してください。

このトピックの内容:

このセクションのトピック:

サブスクリプションおよび配信のシナリオ

。各サブスクリプションでは、選択した配信拡張機能によって、設定できる配信オプションが決まります。 配信拡張機能は、いくつかの配信方法をサポートするモジュールです。 Reporting Services には複数の配信拡張機能が含まれており、配信拡張機能はサード パーティ ベンダーから利用できる可能性があります。

開発者は、その他のシナリオをサポートするために、カスタムの配信拡張機能を作成できます。 詳しくは、「 Implementing a Delivery Extension」をご覧ください。

一般的な Reporting Services サブスクリプションのシナリオを、以下の表に示します。

シナリオ 説明
電子メールでレポートを送信する 個々のユーザーおよびグループにレポートを電子メールで送信します。 サブスクリプションを作成し、配布するレポートを受信するグループの別名または電子メールの別名を指定します。 実行時に Reporting Services によってサブスクリプション データが決定されるようにすることができます。 変化するメンバーの一覧を持っているグループに同じレポートを送信する場合は、クエリを使用して、実行時にサブスクリプションの一覧を取得できます。
オフラインでレポートを表示する ユーザーは、サブスクリプション出力の形式として次のいずれかを選択できます。

- レポート データが含まれている XML ファイル
- CSV (コンマ区切り)
- PDF
- MHTML (Web アーカイブ)
- Microsoft Excel
- TIFF ファイル
- Microsoft Word

アーカイブするレポートは、夜間スケジュールでバックアップされる共有フォルダーに直接送信できます。 ブラウザーに読み込むには時間がかかりすぎる、サイズが大きなレポートは、デスクトップ アプリケーションで表示できる形式で共有フォルダーに送信できます。
キャッシュの事前読み込み パラメーター化されたレポートの複数のインスタンスがあったり、レポートを表示するレポート ユーザーが多数存在したりする場合は、レポートをキャッシュに事前に読み込むことができます。 事前に読み込むと、レポートの表示に必要な処理時間が短縮されます。
レポートをデータ ドリブンにする データ ドリブン サブスクリプションを使用して、実行時にレポート出力、配信オプション、およびレポート パラメーター設定をカスタマイズします。 サブスクリプションでは、クエリを使用して、実行時にデータ ソースから入力値を取得します。 データ ドリブン サブスクリプションを使用すると、サブスクリプションの処理時に決定されるサブスクライバーの一覧にレポートを送信する、文書の差し込み操作を実行できます。

標準のサブスクリプションとデータ ドリブン サブスクリプション

Reporting Services は、 標準 および データ ドリブンの 2 種類のサブスクリプションをサポートします。 個人ユーザーは、標準的なサブスクリプションを作成し、管理します。 標準のサブスクリプションは、サブスクリプションの処理中には変化しない静的な値で構成されます。 標準のサブスクリプションごとに、レポート表示オプション、配信オプション、およびレポート パラメーターのセットが 1 つ用意されます。

データ ドリブン サブスクリプションでは、外部のデータ ソースをクエリすることによって、サブスクリプション情報が実行時に取得されます。受信者、レポート パラメーター、またはアプリケーション形式を指定する値は、この外部のデータ ソースが提供します。 データ ドリブン サブスクリプションは、受信者の一覧が大きい場合、または受信者ごとにレポートの出力を変更する場合に使用できます。 データ ドリブン サブスクリプションを使用するには、クエリの作成に関する専門知識を持っていて、パラメーターの使用方法を理解していることが必要です。 通常、レポート サーバー管理者が、これらのサブスクリプションを作成して管理します。 詳細については、次の記事をご覧ください。

サブスクリプションの要件

レポートに対するサブスクリプションを作成する前に、以下の必要条件を満たす必要があります。

要件 説明
アクセス許可 レポートへのアクセス権は必須です。 レポートをサブスクライブするには、レポートを表示する権限が必要です。

ネイティブ モードのレポート サーバーでは、次のロールの割り当てがサブスクリプションに影響します。

- "個別のサブスクリプションを管理" タスクでは、ユーザーが特定のレポートのサブスクリプションを作成、変更、および削除できます。 定義済みのロールである閲覧者ロールとレポート ビルダー ロールには、このタスクが含まれています。 このタスクを含むロールの割り当てを使用すると、ユーザーは自分が作成するサブスクリプションのみを管理できます。
- "すべてのサブスクリプションを管理" タスクでは、ユーザーがすべてのサブスクリプションにアクセスしてそれらを変更できます。 このタスクは、データ ドリブン サブスクリプションを作成する場合に必要です。 定義済みのロールでは、コンテンツ マネージャー ロールにのみ、このタスクが含まれます。
格納された資格情報 サブスクリプションを作成するには、レポートが保存された資格情報を使用するか、または実行時にデータを取得するために資格情報を使用しないことが必要です。 現在のユーザーの資格情報の権限借用や委任を使用して外部データ ソースに接続するように構成されているレポートは、サブスクライブすることはできません。 保存された資格情報は、Windows アカウントまたはデータベース ユーザー アカウントのいずれかです。 詳細については、「レポート データ ソースに関する認証情報と接続情報を指定する」をご覧ください。

レポートを閲覧するための権限のほか、各サブスクリプションを作成するための権限を所有していることが必要です。 レポート サーバーでは、 [定期的なイベントおよびレポート配信] が有効になっている必要があります。 詳細については、「ネイティブ モード レポート サーバーのサブスクリプションの作成と管理」を参照してください。
レポート内のユーザー依存の値 標準的なサブスクリプションに限り、ユーザー アカウント情報をフィルターに組み込んだレポートや、レポートに表示されるテキストとしてのレポートのサブスクリプションを作成できます。 レポートでは、現在のユーザーとして解釈される User!UserID 式を使用して、ユーザー アカウント名を指定します。 サブスクリプションを作成する時点では、サブスクリプションを作成するユーザーが現在のユーザーとして想定されます。
モデル アイテム セキュリティは無効 モデルにモデル アイテム セキュリティの設定が含まれている場合、データ ソースとしてモデルを使用するレポート ビルダー レポートをサブスクライブすることはできません。 この制限は、モデル アイテム セキュリティを使用するレポートのみが対象となります。
パラメーターの値 レポートでパラメーターを使用する場合、レポート自体または定義するサブスクリプションでパラメーター値を指定する必要があります。 レポートで既定値が定義されている場合は、パラメーター値でその既定値を使用するように設定できます。

配信拡張機能

サブスクリプションは、レポート サーバーに展開された配信拡張機能を使用して、サーバーで処理されます。 既定では、共有フォルダーまたは電子メール アドレスにレポートを送信するサブスクリプションを作成できます。 レポート サーバーが SharePoint 統合モード用に構成されている場合は、レポートを SharePoint ライブラリに送信することもできます。

ユーザーがサブスクリプションを作成するとき、レポートの配信方法を決定するために、利用可能な配信拡張機能の 1 つを選択できます。 Reporting Services には、次の配信拡張機能があります。

配信拡張機能 説明
Windows ファイル共有 レポートを静的なアプリケーション ファイルとして、ネットワーク上の共有フォルダーに配信します。
電子メール 通知またはレポートを、電子メールの添付ファイルまたは URL リンクとして配信します。
SharePoint ライブラリ SharePoint サイトからアクセスできる SharePoint ライブラリに対し、レポートを静的なアプリケーション ファイルとして配信します。 このサイトは、SharePoint 統合モードで実行されたレポート サーバーと統合されている必要があります。
[Null] NULL 配信プロバイダーは、特殊な用途向けの配信拡張機能です。表示する準備が整った、パラメーター化されたレポートを事前にキャッシュする場合に使用されます。ユーザーが個別のサブスクリプションでこの方法を使用することはできません。 NULL 配信は、データ ドリブン サブスクリプションで、事前にデータをキャッシュすることによってレポート サーバーのパフォーマンスを向上させるために管理者が使用します。

Note

レポート配信は、 Reporting Services アーキテクチャの拡張可能な部分です。 サード パーティ ベンダーが作成したカスタム配信拡張機能を使用して、レポートを別の場所やデバイスに送信することができます。 カスタム配信拡張機能の詳細については、「 Implementing a Delivery Extension」を参照してください。

サブスクリプションの要素

サブスクリプション定義は、以下の要素で構成されています。

  • 自動的に実行できるレポート (つまり、格納された資格情報を使用するか、資格情報を使用しないレポート) へのポインター。

  • 配信方法 (たとえば電子メール) および配信モード (たとえば電子メール アドレス) の設定。

  • 特定の形式でレポートを表示する表示拡張機能。

  • サブスクリプションを処理する条件。この条件は、イベントとして示されます。

    通常、レポートを実行する条件は時間ベースです。 たとえば、特定のレポートを火曜日の午後 3:00 (UTC) に実行できます。 ただし、レポートをスナップショットとして実行している場合は、スナップショットが更新されたときに常に実行するようにサブスクリプションを指定できます。

  • レポートの実行時に使用するパラメーター。

    パラメーターは省略可能で、パラメーター値を許可するレポートにのみ指定されます。 通常、サブスクリプションはユーザーが所有しているので、指定されるパラメーター値はサブスクリプションごとに異なります。 たとえば、異なる部門の営業部長は、それぞれ所属する部門のデータを返すパラメーターを使用します。 すべてのパラメーターで値が明示的に定義されているか、有効な既定値が定義されている必要があります。

サブスクリプション情報は、個別のレポートと共にレポート サーバー データベースに格納されます。 サブスクリプションが関連付けられているレポートから切り離して、サブスクリプションを管理することはできません。 説明やその他のカスタム テキスト、またはその他の要素を含むようにサブスクリプションを拡張できません。 サブスクリプションには、以前に一覧表示したアイテムのみを含めることができます。

サブスクリプションの処理方法

Reporting Services には、レポートのスケジュールを設定してユーザーに配信するための機能を提供する、スケジュールおよび配信のプロセッサ機能が含まれています。 レポート サーバーでは常時イベントが監視され、イベントに応答しています。 サブスクリプションに定義されている条件を満たすイベントが発生すると、サブスクリプションが読み取られ、レポートの処理方法と配信方法が決定されます。 レポート サーバーは、サブスクリプションに指定されている配信拡張機能を要求します。 配信拡張機能を実行すると、サブスクリプションから配信情報が抽出され、処理を行うため配信拡張機能に渡されます。

サブスクリプションに定義されている形式に従ってレポートが生成され、指定した送信先にレポートまたは通知が配信されます。 レポートを配信できない場合、レポート サーバーのログ ファイルにエントリが記録されます。 再試行の操作を実行できるようにする場合、最初の配信が失敗したときにもう一度配信を試みるようにレポート サーバーを構成できます。

標準のサブスクリプション処理

標準のサブスクリプションからは、レポートのインスタンスが 1 つ生成されます。 レポートの配信先は、単一の共有フォルダーか、サブスクリプションに指定されている複数の電子メール アドレスになります。 レポートのレイアウトおよびデータは変わりません。 パラメーターを使用する場合、標準のサブスクリプション処理ではレポートのパラメーターごとに 1 つの値が使用されます。

データ ドリブン サブスクリプションの処理

データ ドリブン サブスクリプションからは、レポートのインスタンスが複数生成され、インスタンスを複数の送信先に配信できます。 サブスクライバーの結果セットからパラメーター値が渡された場合、レポートのレイアウトは変わりませんが、レポートのデータが変わる場合があります。 レポートがどのように表示されるか、レポートが電子メールに添付されるかリンクされるかに影響する配信オプション。 これらのオプションは、値が行セットから渡されるときにサブスクライバーによって異なる場合もあります。

データ ドリブン サブスクリプションからは、多数の配信が生成されることがあります。 サブスクリプション クエリから返された行セットの 1 行ごとに 1 件の配信が生成されます。

レポート配信の特性

標準のサブスクリプションにより配信されるレポートは、通常は静的なレポートとして表示されます。 それらのレポートは、直前のレポート実行スナップショットを基にするか、配信を完了する静的なレポートとして生成されます。 要求時に実行されるレポートに対してサブスクリプションの [リンクを含める] オプションが選択されている場合、ハイパーリンクを選択するとレポート サーバー側でレポートが実行されます。

Note

URL として配信されるレポートはレポート サーバーに接続された状態で、表示している間に更新や削除が行われる場合があります。 サブスクリプションに対して選択する配信オプションによって、レポートを URL として配信するか、電子メール メッセージの本文に埋め込むか、または添付ファイルとして送信するかを決定します。

データ ドリブン サブスクリプションによって配信されるレポートは、サブスクリプションが処理されている間に再生成される場合があります。 レポート サーバーは、データ ドリブン サブスクリプションを完了するために、レポートまたはレポートのデータセットの特定のインスタンスをロックしません。 サブスクリプションでサブスクライバーごとに異なるパラメーターの値を使用した場合、それぞれに合わせた出力を生成するためにレポートが再生成されます。 基になるデータは、最初のレポート コピーが作成されて配信された後に更新される可能性があります。 レポートを更新すると、プロセスの後半でレポートを取得するユーザーに、異なる結果セットに基づくデータが表示されることがあります。 スナップショットとして実行されるレポートを使用すると、すべてのサブスクライバーに同じレポートのインスタンスが確実に配信されます。 ただし、スケジュールに設定されているスナップショットの更新がサブスクリプションの処理中に行われた場合、受け取るレポートのデータがユーザー間で異なることがあります。

サブスクリプション処理の開始

レポート サーバーでは、スケジュールで指定されたタイム ドリブン イベントまたはスナップショット更新イベントの 2 種類のイベントを使用して、サブスクリプション処理を開始します。

タイム ドリブン トリガーは、レポート固有のスケジュールまたは共有スケジュールを使用し、サブスクリプションが実行される日時を指定します。 要求時レポートおよびキャッシュされたレポートでは、スケジュールはトリガー オプションのみです。

スナップショット更新イベントは、レポート スナップショットのスケジュールされた更新を使用して、サブスクリプションを開始します。 レポートが新しいデータに更新されるたびに開始されるサブスクリプションを定義できます。 サブスクリプションは、レポートに設定されているレポート実行プロパティに基づいてトリガーされます。

サブスクリプションのプログラムによる制御

Reporting Services オブジェクト モデルでは、プログラムを使用してサブスクリプションとサブスクリプションの処理を監査および制御できます。 次の記事と開始方法をご覧ください。

データ ドリブン サブスクリプションの作成 (SSRS チュートリアル)
スケジュール
Reporting Services レポート サーバー (ネイティブ モード)
Reporting Services のサブスクリプションを監視する