次の方法で共有


集計のデザイン (XMLA)

集計デザインは、集計の格納時に複数のパーティションで同じ構造を確実に使用するようにするため、特定のメジャー グループのパーティションに関連付けられるものです。 パーティションに同じストレージ構造を使用すると、 MergePartitions コマンドを使用して後でマージできるパーティションを簡単に定義できます。 集計デザインの詳細については、「 集計と集計デザイン」を参照してください。

集計デザインの集計を定義するには、XML for Analysis ( XMLA) で DesignAggregations コマンドを使用できます。 DesignAggregations コマンドには、参照として使用する集計デザインとその参照に基づいてデザイン プロセスを制御する方法を識別するプロパティがあります。 DesignAggregations コマンドとそのプロパティを使用すると、集計を繰り返しまたはバッチで設計し、結果の設計統計を表示して設計プロセスを評価できます。

集計デザインの指定

DesignAggregations コマンドの Object プロパティには、既存の集計デザインへのオブジェクト参照が含まれている必要があります。 オブジェクト参照には、データベース識別子、キューブ識別子、メジャー グループ識別子、および集計デザイン識別子が含まれます。 既存の集計デザインがない場合、エラーが発生します。

デザイン プロセスの制御

DesignAggregations コマンドの次のプロパティを使用して、集計デザインの集計を定義するために使用するアルゴリズムを制御できます。

  • Steps プロパティは、DesignAggregations コマンドがクライアント アプリケーションに制御を返す前に実行する反復回数を決定します。

  • Time プロパティは、DesignAggregations コマンドがクライアント アプリケーションに制御を返すまでの時間 (ミリ秒) を決定します。

  • Optimization プロパティは、DesignAggregations コマンドが達成しようとするパフォーマンス向上の推定パーセンテージを決定します。 集計を反復的にデザインする場合、このプロパティは最初のコマンドで送信するだけで十分です。

  • Storage プロパティは、DesignAggregations コマンドで使用されるディスク ストレージの推定量をバイト単位で決定します。 集計を反復的にデザインする場合、このプロパティは最初のコマンドで送信するだけで十分です。

  • Materialize プロパティは、DesignAggregations コマンドでデザイン プロセス中に定義された集計を作成する必要があるかどうかを決定します。 集計を反復的にデザインする場合、デザインした集計を保存する用意ができるまで、このプロパティは false に設定しておく必要があります。 true に設定した場合、現在のデザイン プロセスが終了し、定義された集計は指定した集計デザインに追加されます。

クエリの指定

DesignAggregations コマンドは、Queries プロパティに 1 つ以上の Query 要素を含めることで、使用法ベースの最適化コマンドをサポートします。 Queries プロパティには、1 つ以上の Query 要素を含めることができます。 Queries プロパティに Query 要素が含まれていない場合、Object 要素で指定された集計デザインでは、一般的な集計セットを含む既定の構造体が使用されます。 この一般的な集計セットは、DesignAggregations コマンドの最適化プロパティとストレージ プロパティで指定された条件を満たすように設計されています。

Query 要素は、最もよく使用するクエリを対象とする集計を定義するためにデザイン プロセスが使用する、目標クエリを表します。 独自の目標クエリを指定することも、Microsoft SQL Server SQL Server Analysis Servicesのインスタンスによってクエリ ログに格納されている情報を使用して、最もよく使用されるクエリに関する情報を取得することもできます。 Usage-Based最適化ウィザードは、クエリ ログを使用して、 DesignAggregations コマンドを送信するときに、時間、使用状況、または指定されたユーザーに基づいて目標クエリを取得します。 詳細については、「 使用法ベースの最適化ウィザード F1 ヘルプ」を参照してください。

集計を繰り返し設計する場合は、最初の DesignAggregations コマンドでゴール クエリを渡すだけで済みます。これは、SQL Server Analysis Services インスタンスがこれらの目標クエリを格納し、後続の DesignAggregations コマンドでこれらのクエリを使用するためです。 反復処理の最初の DesignAggregations コマンドで目標クエリを渡した場合、後続の DesignAggregations コマンドの Queries プロパティに目標クエリが含まれていると、エラーが発生します。

Query 要素には、以下の引数を含むコンマ区切りの値が含まれます。

Frequency,Dataset[,Dataset...]

頻度
クエリが以前に実行された回数に対応する重み係数です。 Query 要素が新しいクエリを表す場合、 Frequency の値はクエリを評価するためにデザイン プロセスによって使用される重み係数を表します。 この値が大きいほど、デザイン プロセスでクエリに対して付けられる重みが増加します。

データセット
ディメンション内のどの属性をクエリに含めるかを指定する数値文字列です。 この文字列の文字数は、ディメンション内の属性の数と一致している必要があります。 0 は、その位置にある属性が、指定されたディメンションのクエリに含まれないことを示します。1 は、その位置にある属性が、指定されたディメンションのクエリに含まれることを示します。

たとえば文字列 "011" は、3 つの属性を持つディメンションを処理するクエリの中に、2 番目と 3 番目の属性が含まれることを示しています。

注意

いくつかの属性は、データセットでの考慮の対象から除外されます。 除外される属性の詳細については、「 クエリ要素 (XMLA)」を参照してください。

集計デザインを含むメジャー グループ内の各ディメンションは、 Query 要素の Dataset の値によって表されます。 Dataset の値の順序は、メジャー グループに含まれるディメンションの順序と一致している必要があります。

反復処理またはバッチ処理を使用した集計のデザイン

DesignAggregations コマンドは、設計プロセスに必要な対話機能に応じて、反復プロセスまたはバッチ プロセスの一部として使用できます。

反復処理を使用した集計のデザイン

集計を反復的に設計するには、複数の DesignAggregations コマンドを送信して、デザイン プロセスを細かく制御します。 集計のデザイン ウィザードでも、同じアプローチを使用してデザイン プロセスを細かく制御します。 詳細については、「 集計デザイン ウィザード F1 ヘルプ」を参照してください。

注意

集計を反復処理によってデザインするには、明示的なセッションが必要です。 明示的なセッションの詳細については、「 接続とセッションの管理 (XMLA)」を参照してください。

反復プロセスを開始するには、まず、次の情報を含む DesignAggregations コマンドを送信します。

  • デザイン プロセス全体の対象となる Storage プロパティと Optimization プロパティの値。

  • デザイン プロセスの最初のステップが制限されている Steps プロパティと Time プロパティ値。

  • 使用量ベースの最適化が必要な場合は、デザイン プロセス全体の対象となる目標クエリを含む Queries プロパティ。

  • Materialize プロパティを false に設定します。 このプロパティを false に設定することは、コマンドの完了時に、定義された集計がデザイン プロセスによって集計デザインに保存されないことを意味します。

最初の DesignAggregations コマンドが完了すると、このコマンドはデザイン統計を含む行セットを返します。 これらのデザインの統計を評価して、デザイン プロセスを継続するか、あるいは終了するかを判断することができます。 プロセスを続行する必要がある場合は、デザイン プロセスのこのステップが制限されている StepsTime の値を含む別の DesignAggregations コマンドを送信します。 そして結果の統計を評価し、デザイン プロセスを継続すべきかどうかを判断します。 DesignAggregations コマンドを送信し、結果を評価するこの反復的なプロセスは、目標に達し、適切な集計セットが定義されるまで続行されます。

必要な集計のセットに到達したら、最終的な DesignAggregations コマンドを 1 つ送信します。 この最後の DesignAggregations コマンドでは、 Steps プロパティを 1 に設定し、 Materialize プロパティを true に設定する必要があります。 これらの設定を使用すると、この最後の DesignAggregations コマンドによってデザイン プロセスが完了し、定義された集計が集計デザインに保存されます。

バッチ処理を使用した集計のデザイン

また、デザイン プロセス全体が対象であり制限されている StepsTimeStorageOptimization プロパティの値を含む単一の DesignAggregations コマンドを送信することで、バッチ プロセスで集計を設計することもできます。 使用量ベースの最適化が必要な場合は、設計プロセスの対象となる目標クエリも Queries プロパティに含める必要があります。 また、 Materialize プロパティが true に設定されていることを確認します。これにより、コマンドの終了時に、定義された集計が集計デザインに保存されます。

バッチ処理による集計のデザインは、暗黙のセッションまたは明示的なセッションのいずれでも行うことができます。 暗黙的および明示的なセッションの詳細については、「 接続とセッションの管理 (XMLA)」を参照してください。

デザインの統計を返す処理

DesignAggregations コマンドがクライアント アプリケーションに制御を返すと、コマンドは、コマンドのデザイン統計を表す 1 つの行を含む行セットを返します。 行セットに含まれる列は、次の表のとおりです。

データ型 説明
手順 Integer クライアント アプリケーションに制御を返すまでに、コマンドによって行われたステップの数です。
Time Long integer クライアント アプリケーションに制御を返すまでに、コマンドで経過したミリ秒単位の時間です。
最適化 Double クライアント アプリケーションに制御を返すまでに、コマンドによって達成されたパフォーマンス向上率の予測値です。
Storage Long integer クライアント アプリケーションに制御を返すまでに、コマンドによって使用されたバイト数の予測値です。
集計関数 Long integer クライアント アプリケーションに制御を返すまでに、コマンドによって定義された集計の数です。
LastStep Boolean 行セット内のデータがデザイン プロセス内の最後のステップを表しているかどうかを示します。 コマンドの Materialize プロパティが true に設定されている場合、この列の値は true に設定されます。

反復デザインとバッチ デザインの両方で、 DesignAggregations コマンドの後に返される行セットに含まれるデザイン統計を使用できます。 反復処理によるデザインの場合、進行状況の判別と表示を行うために、デザインの統計を使用できます。 集計をバッチ処理によってデザインする場合は、コマンドによって作成された集計の数を判断するために、デザインの統計を使用できます。

参照

Analysis Services での XMLA による開発