計算
計算とは、Microsoft SQL Server 2005 Analysis Services のキューブ内で計算されるメンバ、名前付きセット、またはスコープ割り当ての定義に使用する多次元式 (MDX) またはスクリプトを指します。計算により、キューブのデータによって定義されるオブジェクトではなく、キューブの他の部分、他のキューブ、さらには Analysis Services データベースの外部にある情報を参照できる式によって定義されるオブジェクトを追加できます。計算により、キューブの機能を拡張し、ビジネス インテリジェンス アプリケーションの柔軟性と能力を向上させることができます。計算スクリプトの作成の詳細については、「Microsoft SQL Server 2005 の MDX スクリプトの紹介」を参照してください。MDX クエリおよび計算に関連するパフォーマンスの問題の詳細については、「SQL Server 2005 Analysis Services パフォーマンス ガイド」を参照してください。
計算されるメンバ
計算されるメンバとは、値が実行時に計算されるメンバのことです。その計算には、計算されるメンバの定義時に指定した多次元式 (MDX) が使用されます。計算されるメンバは、ビジネス インテリジェンス アプリケーションで他のメンバと同様に使用できます。キューブに保存されるのは定義のみであるため、計算されるメンバによってキューブのサイズが大きくなることはありません。値はクエリへの応答時にメモリ内で計算されます。
計算されるメンバは、メジャー ディメンションを含むすべてのディメンションで定義できます。メジャー ディメンションに作成された計算されるメンバは、計算されるメジャーと呼ばれます。
通常、計算されるメンバはキューブの既存のデータに基づいていますが、データに算術演算子、数値、および関数を組み合わせて複雑な式を作成することもできます。また、LookupCube などの MDX 関数を使用し、Analysis Services データベースにある他のキューブのデータにアクセスすることも可能です。Analysis Services には標準化された Visual Studio 関数ライブラリが含まれているため、ストアド プロシージャを使用して、現在の Analysis Services データベース以外のソースからデータを取得することができます。ストアド プロシージャの詳細については、「ストアド プロシージャを使用した作業 (Analysis Services)」を参照してください。
たとえば、船会社の経営陣が積載量に対するコストに基づいて、利益の上がる貨物の種類を特定する場合を考えてみます。経営陣が使用する Shipments キューブには、ディメンションとして Cargo、Fleet、および Time が含まれ、メジャーとして Price_to_Ship、Cost_to_Ship、および Volume_in_Cubic_Meters が含まれています。ただし、収益性に関するメジャーは含まれていません。この場合、計算されるメンバを Profit_per_Cubic_Meter という名前のメジャーとしてキューブに作成できます。その値を計算するには、次のように、式の中で既存のメジャーを組み合わせます。
([Measures].[Price_to_Ship] - [Measures].[Cost_to_Ship]) /
[Measures].[Volume_in_Cubic_Meters]
計算されるメンバを作成した後、Shipments キューブを参照すると、Profit_per_Cubic_Meter が他のメジャーと共に表示されます。
計算されるメンバを作成するには、キューブ デザイナの [計算] タブを使用します。詳細については、「計算されるメンバの定義」を参照してください。
名前付きセット
名前付きセットとは、セットを返す CREATE SET MDX ステートメント式であり、MDX 式は、Microsoft SQL Server 2005 Analysis Services (SSAS) でキューブの定義の一部として保存されます。名前付きセットは、多次元式 (MDX) クエリで再使用するために作成されます。名前付きセットを使用すると、ビジネス ユーザーは、クエリを簡素化し、複雑で頻繁に使用されるセット式にセット式ではなくセット名を使用できます。関連トピック : 名前付きセットの定義
スクリプト コマンド
スクリプト コマンドは、キューブの定義の一部として含まれる MDX スクリプトです。スクリプト コマンドを使用すると、キューブの一部のみに対する計算のスコープ割り当てなど、MDX でサポートされるほとんどすべてのアクションをキューブで実行できます。SQL Server 2005 Analysis Services (SSAS) では、MDX スクリプト実行時の特定の時点で、キューブ全体またはキューブの特定のセクションにスクリプトを適用することができます。既定のスクリプト コマンドである CALCULATE ステートメントを実行すると、既定の範囲に基づいて、キューブのセルに集計データが設定されます。
既定の範囲はキューブ全体ですが、サブキューブと呼ばれる制限された範囲を定義して、特定のキューブ領域にのみ MDX スクリプトを適用することもできます。 SCOPE ステートメントは、範囲が終了するか、再定義されるまで、計算スクリプト内の後続の MDX 式およびステートメントのすべての範囲を定義します。THIS ステートメントを使用すると、MDX 式を現在の範囲に適用できます。BACK_COLOR ステートメントを使用すると、現在の範囲内のセルの背景色を指定して、デバッグに役立てることができます。
たとえば、スクリプト コマンドを使用すると、以前の期間の売上の重み付け値を基にして、期間と販売区域全体を対象に、販売ノルマを従業員に割り当てることができます。