ドリル・スルー・レポートの設計

データベース・マネージャは、列マッピングを作成してから1つ以上のドリル可能領域を定義することで、ドリル・スルー・レポート定義を作成できます。

ドリル・スルー・レポートを設計する際の一般的な考慮事項

作成したドリル・スルー・レポートは、データベース・インスペクタの「スクリプト」セクションでキューブと関連付けられています。

すべてのドリル・スルー・レポート定義に列マッピングとドリル可能領域を含める必要があります。オプションで、ドリル・スルー・レポートに外部ソース・データ接続を提供するデータソース内にパラメータ化問合せが存在する場合は、ランタイム・パラメータのマッピングを定義できます。

ドリル・スルー・レポート定義を作成するには、データベース・マネージャ以上である必要があります。

外部ソース・システム(RDBMS)から、またはファイルからデータをプルするドリル・スルー・レポートを作成できます。

注:

ドリル・スルー・レポートのデータソースがOracle Databaseに接続されている場合、一時表の使用オプションを選択して、SQLの“IN”句に多数の値を持つ問合せのパフォーマンスを高めることができます。

Web URLにアクセスするようにドリル・スルー・レポートを設計することもできます。

ドリル・スルー・レポートの列マッピングの定義

列マッピングでは、レポートに含める必要がある外部ソース列、それらの列のマップ先となるEssbaseディメンション、および提供するアクセスの深さを示す世代/レベル・フィルタ条件を定義します。

列マッピングの詳細を理解するには、「ドリル・スルー・レポート定義」を参照してください。

列マッピングを定義します:

  1. 「アプリケーション」ページでアプリケーションを開き、キューブを開きます。

  2. 左側のパネルで「スクリプト」を選択します。

  3. 「ドリル・スルー・レポート」をクリックします。

  4. 「作成」をクリックし、メニューから「データソース」を選択します。

  5. 「名前」フィールドで、レポートの名前を追加します。

  6. 「データソース」フィールドで、使用するデータソースを選択します。

  7. 列マッピングを作成します:

    1. 外部データソースから、レポートに含める列を選択します。

    2. 各列をマップするディメンションを選択します。

    3. マッピングのフィルタ条件を選択します。たとえば、「レベル0」、「世代」または「なし」です(ディメンション・マッピング用)。


      ドリル・スルー・レポートの列マッピングのイメージ。

    4. 終了したら、「ドリル可能リージョン」をクリックします。「ドリル・スルー・レポートのドリル可能領域の定義」の説明に従って領域を定義しないと、ドリル・スルー・レポート定義を保存できません。

列マッピングを定義します:

  1. アプリケーション・ページで、アプリケーションを展開します。

  2. キューブ名の右にある「アクション」メニューから、「検査」をクリックします。

  3. アプリケーション・インスペクタで、「スクリプト」タブを選択します。

  4. 「ドリル・スルー・レポート」を選択します

  5. 「作成」をクリックし、ドロップダウン・メニューから「データソース」を選択します。

  6. 「名前」フィールドで、レポートの名前を追加します。

  7. 「データソース」フィールドで、使用するデータソースを選択します。

  8. 列マッピングを作成します:

    1. 外部データソースから、レポートに含める列を選択します。

    2. 各列をマップするディメンションを選択します。

    3. マッピングのフィルタ条件を選択します。たとえば、「レベル0」、「世代」または「なし」です(ディメンション・マッピング用)。


      ドリル・スルー・レポート・ウィザードの列マッピングのイメージ。

  9. 終了したら、「ドリル可能リージョン」をクリックします。「ドリル・スルー・レポートのドリル可能領域の定義」の説明に従って領域を定義しないと、ドリル・スルー・レポート定義を保存できません。

ドリル・スルー・レポートのドリル可能領域の定義

データの外部ソースにアクセス(ドリル・スルー)できるEssbaseキューブの1つ以上のドリル可能領域を定義します。

  1. 列マッピングが完了したら、「ドリル可能リージョン」をクリックします。

  2. プラス記号をクリックし、次のいずれかの方法を選択します:
    • 空の行をダブルクリックし、計算構文(メンバー名とメンバー・セット関数)を使用して領域を定義します。
    • 鉛筆アイコンをクリックしてドリル可能リージョン・セレクタを開き、追加するメンバーを選択して右クリックし、メニュー・オプションから選択して領域を定義します。
      Redwoodのドリル可能リージョン・セレクタのイメージ。

  3. 「保存」をクリックします。ドリル・スルー・レポートが正常に更新されたかどうかを示すメッセージが表示されます。


    ドリル・スルー・レポート・ウィザードの「ドリル可能リージョン」タブと、Market、Year、Scenario、SalesおよびProductのレベル1メンバーに対して定義されたドリル可能領域のイメージ。

ドリル可能領域の例

次の例は、Smart Viewのドリル可能領域を青色で強調表示して示しています。

例1

Market、Year、Scenarioディメンションの最上位、メンバーSales、およびProductディメンションのすべてのレベル1メンバーに対してドリル可能領域を定義するには、次を使用します:

Market,Year,Scenario,Sales,@LEVMBRS(Product,1)

Smart Viewシートにドリルすると、結果のグリッドは次のようになります:


ドリル可能メンバーが青色で強調表示されたSmart Viewグリッドのイメージ。定義された領域は、Market,Year,Scenario,Sales,@LEVMBRS(Product,1)です。

例2

Marketの子孫に対してドリル可能領域を定義するには、次を使用します:

@DESCENDANTS(Market)

Smart Viewシートにドリルすると、結果のグリッドは次のようになります:


ドリル可能セルが青色で強調表示されたSmart Viewグリッドのイメージ。定義された領域は、@DESCENDANTS(Market)です

例3

Productディメンションの世代3のメンバー、Market、Year、Scenarioディメンションの最上位、およびメンバーSalesに対してドリル可能領域を定義するには、次を使用します:

Market,Year,Scenario,Sales,@GENMBRS(Product,3)

Smart Viewシートにドリルすると、結果のグリッドは次のようになります:


ドリル可能セルが青色で強調表示されたSmart Viewグリッドのイメージ。定義された領域は、Market,Year,Scenario,Sales,@GENMBRS(Product,3)です

ドリル・スルー・レポートのパラメータの実装

ドリル・スルー・レポートの柔軟性を向上するために、ドリル・スルーを設計してパラメータを実装できます。

データベース・マネージャ以上である場合、ドリル・スルー・レポートにパラメータ化されたデータソース問合せを実装できます。

前提条件: アプリケーション・マネージャ以上から、固定(デフォルト)値代替変数、またはパラメータとしての外部ユーザー定義関数を使用するデータソースに対するアクセス権が付与されています。

Essbaseは、実行時にパラメータの値を認識し、ドリル・スルーの実行時にEssbaseによって生成される問合せにその現在の値を挿入します。

ドリル・スルー・レポート定義で、ランタイム・パラメータのディメンション、世代およびレベル・マッピングをオプションで追加できます。これにより、現在の変数コンテキストに基づいて、ドリル・スルー・レポートの結果をさらにカスタマイズできます。

Essbaseで変数に基づいて動的にドリル・スルー・レポートを作成する場合は、次のワークフローに従います:

  1. 基礎となるデータソース問合せでデータソースのパラメータの実装を行います。これは、アプリケーション・マネージャ以上が行う必要があります。

  2. データソースに関連付けられたドリル・スルー・レポート定義を作成します。

  3. オプションで、ドリル・スルー・レポート定義内でパラメータの使用にランタイム・カスタマイズを加えます。次に例を示します。

  4. ドリル・スルー・レポートを実行して予想どおりの動作であることをテストおよび検証し、Essbaseサーバー・プラットフォーム・ログを使用したドリル・スルーのデバッグを行います。

ランタイム・パラメータとユーザー定義関数

後続のユースケースの例は、次の前提条件に基づいています:

  • ユーザー定義関数getMonthsが外部ソース・システムに定義されています。関数によって、月のカンマ区切りリストが返されます。

  • ドリル・スルー・レポート定義に使用されるデータソースが、次のようにgetMonths関数をコールする問合せを使用して定義されています:

    select * from SampleBasic where month in (getMonths(?))

ランタイム・パラメータのレベル0 (再帰的)マッピング

ランタイム・パラメータがレベル0のYearにバインドされている場合のドリル・スルー・レポート定義


ドリル・スルー・レポート定義の「ランタイム・パラメータ」タブ。パラメータ: Param1。変数: 選択済。値: Sample.mnth。ディメンション: Year。世代のバインディング: Level0 [レベル]

Smart ViewユーザーがYearディメンションのQtr1をドリル・スルーする場合、ドリル・スルー・レポートにはJan、Feb、Marが含まれます。Smart ViewユーザーがYearをドリル・スルーする場合、ドリル・スルー・レポートにはJan、Feb、Mar、Apr、May、Jun、Jul、Aug、Sep、Oct、Nov、Decが含まれます。

ランタイム・パラメータの世代マッピング

ランタイム・パラメータがQuarter世代のYearにバインドされている場合のドリル・スルー・レポート定義


ドリル・スルー・レポート定義の「ランタイム・パラメータ」タブ。パラメータ: Param1。変数: 選択済。値: Sample.mnth。ディメンション: Year。世代のバインディング: Quarter [世代]

Smart ViewユーザーがYearディメンション・メンバーをドリル・スルーする場合、ドリル・スルー・レポートにはQtr1、Qtr2、Qtr3、Qtr4が含まれます。

注:

列マッピングと重複するランタイム・パラメータのディメンション/世代のバインディングを設定することは無効です。この場合に生成される問合せは常にnullセットです。