サブスクリプションと配信 (Reporting Services)
Reporting Services サブスクリプションは、特定の時刻で、またはイベントへの応答として、指定されたファイル形式でレポートを配信する構成です。 たとえば、毎週水曜日に、MonthlySales.rdl レポートを Microsoft Word 文書としてファイル共有に保存します。 サブスクリプションを使用して、レポート配信のスケジュールや自動化を設定したり、レポート パラメーターの特定の値セットを指定したりすることができます。
1 つのレポートに複数のサブスクリプションを作成して、サブスクリプションのオプションを変更することができます。たとえば、異なるパラメーター値を指定して、西部地域の売上レポート、東部地域の売上レポート、全地域の売上レポートのように、3 つのバージョンのレポートを作成できます。
サブスクリプションは、 SQL Serverのすべてのエディションで使用できるわけではありません。 SQL Serverのエディションでサポートされている機能の一覧については、「SQL Server 2014 のエディションでサポートされる機能」を参照してください。
Note
SQL Server 2008 R2Reporting Services 以降では、サブスクリプションの所有権をプログラムで譲渡できます。 サブスクリプションの所有権の転送に使用できるユーザー インターフェイスはありません。 詳細については、「PowerShell を使用してサブスクリプション所有者Reporting Services変更および一覧表示する」および「サブスクリプションの実行」ChangeSubscriptionOwnerを参照してください。
このトピックの内容:
このセクションのトピック:
Reporting Services の電子メール配信 。レポート サーバーのファイル共有の配信操作および構成について説明します。
File Share Delivery in Reporting Services レポート サーバーのファイル共有の配信操作および構成について説明します。
SharePoint Library Delivery in Reporting Services SharePoint ライブラリへのサブスクリプションの配信について説明します。
データ ドリブン サブスクリプション 実行時にレポート出力をカスタマイズする際のデータ ドリブン サブスクリプションの使用に関する情報を記載しています。
Use PowerShell to Change and List Reporting Services Subscription Owners and Run a Subscription
サブスクリプションおよび配信のシナリオ
サブスクリプションごとに配信オプションを構成し、使用可能なオプションは選択する配信拡張機能によって決まります。 配信拡張機能は、いくつかの配信方法をサポートするモジュールです。 Reporting Services には複数の配信拡張機能が含まれており、配信拡張機能はサード パーティ ベンダーから利用できる可能性があります。
開発者は、その他のシナリオをサポートするために、カスタムの配信拡張機能を作成できます。 詳しくは、「 Implementing a Delivery Extension」をご覧ください。
一般的な Reporting Services サブスクリプションのシナリオを、以下の表に示します。
シナリオ | 説明 |
---|---|
電子メールでレポートを送信する | 個々のユーザーおよびグループにレポートを電子メールで送信します。 サブスクリプションを作成し、配布するレポートを受信するグループの別名または電子メールの別名を指定します。 実行時に Reporting Services によってサブスクリプション データが決定されるようにすることができます。 変化するメンバーの一覧を持っているグループに同じレポートを送信する場合は、クエリを使用して、実行時にサブスクリプションの一覧を取得できます。 |
オフラインでレポートを表示する | アーカイブするレポートは、夜間スケジュールでバックアップされる共有フォルダーに直接送信できます。 ブラウザーに読み込むには時間がかかりすぎる、サイズが大きなレポートは、デスクトップ アプリケーションで表示できる形式で共有フォルダーに送信できます。 ユーザーは、サブスクリプション出力の形式として次のいずれかを選択できます。 レポート データが含まれている XML ファイル CSV (コンマ区切り) 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 種類のイベントを使用して、サブスクリプション処理を開始します。
タイム ドリブン トリガーは、レポート固有のスケジュールまたは共有スケジュールを使用し、サブスクリプションが実行される日時を指定します。 要求時レポートおよびキャッシュされたレポートでは、スケジュールはトリガー オプションのみです。
スナップショット更新イベントは、レポート スナップショットのスケジュールされた更新を使用して、サブスクリプションを開始します。 レポートに設定されているレポート実行プロパティを基に、レポートが新しいデータに更新されるたびに開始されるサブスクリプションを定義できます。
参照
Data-Driven サブスクリプションの作成 (SSRS チュートリアル)スケジュールReporting Servicesレポート サーバー (ネイティブ モード)ネイティブ モード のレポート サーバー モニター Reporting Services サブスクリプションのサブスクリプションの作成と管理