olapR を使って R で MDX クエリを作成する方法
適用対象: SQL Server 2016 (13.x) 以降のバージョン
SQL Server Machine Learning Services パッケージの olapR では、SQL Server Analysis Services でホストされているキューブに対する MDX クエリがサポートされています。 既存のキューブに対してクエリを作成したり、ディメンションやその他のキューブ オブジェクトを調べたり、既存の MDX クエリを貼り付けてデータを取得したりできます。
この記事では、olapR パッケージの主な 2 つの用途について説明します。
次の操作はサポートされていません。
- テーブル モデルに対する DAX クエリ
- 新しい OLAP オブジェクトの作成
- パーティションへの書き戻し (メジャーまたは合計を含む)
R から MDX クエリを作成する
OLAP データ ソース (SSAS インスタンス) および MSOLAP プロバイダーを指定する接続文字列を定義します。
OlapConnection(connectionString)
関数を使って MDX クエリのハンドルを作成し、接続文字列を渡します。Query()
コンストラクターを使って、クエリ オブジェクトをインスタンス化します。以下のヘルパー関数を使って、MDX クエリに含めるディメンションとメジャーについての詳細を提供します。
cube()
: SSAS データベースの名前を指定します。 名前付きインスタンスに接続する場合は、マシン名とインスタンス名を指定します。columns()
: ON COLUMNS 引数で使うメジャーの名前を指定します。rows()
: ON ROWS 引数で使うメジャーの名前を指定します。slicers()
: スライサーとして使うフィールドまたはメンバーを指定します。 スライサーとは、すべての MDX クエリ データに適用されるフィルターのようなものです。axis()
: クエリで使う追加の軸の名前を指定します。OLAP キューブは、最大で 128 個のクエリ軸を含むことができます。 一般に、最初の 4 つの軸は、列、行、ページ、およびチャプターと呼ばれます。
クエリが比較的単純な場合は、
columns
、rows
などの関数を使ってクエリを作成できます。 ただし、axis()
関数を使って 0 以外のインデックス値を指定し、多くの修飾子を持つ MDX クエリを作成したり、修飾子として余分なディメンションを追加したりすることもできます。
結果の形に応じて、ハンドル、および完成した MDX クエリを、次のいずれかの関数に渡します。
executeMD
: 多次元配列を返しますexecute2D
: 2 次元 (表形式) のデータ フレームを返します
R から有効な MDX クエリ を実行する
OLAP データ ソース (SSAS インスタンス) および MSOLAP プロバイダーを指定する接続文字列を定義します。
OlapConnection(connectionString)
関数を使って MDX クエリのハンドルを作成し、接続文字列を渡します。MDX クエリのテキストを格納する R 変数を定義します。
結果の形に応じて、ハンドルおよび MDX クエリを含む変数を
executeMD
またはexecute2D
関数に渡します。executeMD
: 多次元配列を返しますexecute2D
: 2 次元 (表形式) のデータ フレームを返します
例
次の例は、AdventureWorks データ マートとキューブ プロジェクトに基づいています。このプロジェクトは、Analysis Services に簡単に復元できるバックアップ ァイルを含め、複数のバージョンで広く利用できるためです。 既存のキューブがない場合は、次のいずれかのオプションを使用してサンプル キューブを取得します。
Analysis Services チュートリアルのレッスン 4: OLAP キューブの作成までの手順に従って、これらの例で使用されているキューブを作成します
既存のキューブをバックアップとしてダウンロードし、Analysis Services のインスタンスに復元します。 たとえば、このサイトは、完全に処理されたキューブを zip 形式: Adventure Works 多次元モデル SQL 2014 で提供します。 ファイルを抽出し、ご自身の SSAS インスタンスに復元します。 詳細については、バックアップと復元に関するページ、または Restore-ASDatabase コマンドレットに関するページをご覧ください。
1.スライサーを使う基本的な MDX
この MDX クエリは、インターネットの販売数と販売金額の数と金額の メジャー を選択し、列軸に設定します。 SalesTerritory ディメンションのメンバーを スライサーとして追加し、オーストラリアからの販売のみが計算で使われるようにクエリをフィルターします。
SELECT {[Measures].[Internet Sales Count], [Measures].[InternetSales-Sales Amount]} ON COLUMNS,
{[Product].[Product Line].[Product Line].MEMBERS} ON ROWS
FROM [Analysis Services Tutorial]
WHERE [Sales Territory].[Sales Territory Country].[Australia]
- 列では、コンマ区切りの文字列の要素として複数のメジャーを指定できます。
- 行軸では、"Product Line" ディメンションのすべての可能な値 (すべての MEMBERS) を使います。
- このクエリは、すべての国と地域からのインターネット販売の "ロールアップ" サマリーを含む 3 列のテーブルを返します。
- WHERE 句では、"スライサー軸" を指定します。 この例では、スライサーは、SalesTerritory ディメンションのメンバーを使って、オーストラリアからの販売のみが計算で使われるようにクエリをフィルター処理します。
olapR で提供される関数を使ってこのクエリを作成するには
cnnstr <- "Data Source=localhost; Provider=MSOLAP; initial catalog=Analysis Services Tutorial"
ocs <- OlapConnection(cnnstr)
qry <- Query()
cube(qry) <- "[Analysis Services Tutorial]"
columns(qry) <- c("[Measures].[Internet Sales Count]", "[Measures].[Internet Sales-Sales Amount]")
rows(qry) <- c("[Product].[Product Line].[Product Line].MEMBERS")
slicers(qry) <- c("[Sales Territory].[Sales Territory Country].[Australia]")
result1 <- executeMD(ocs, qry)
名前付きインスタンスの場合、R の制御文字と見なすことができる文字は必ずエスケープしてください。たとえば、次の接続文字列では、ContosoHQ という名前のサーバー上のインスタンス OLAP01 を参照します。
cnnstr <- "Data Source=ContosoHQ\\OLAP01; Provider=MSOLAP; initial catalog=Analysis Services Tutorial"
事前定義された MDX 文字列としてこのクエリを実行するには
cnnstr <- "Data Source=localhost; Provider=MSOLAP; initial catalog=Analysis Services Tutorial"
ocs <- OlapConnection(cnnstr)
mdx <- "SELECT {[Measures].[Internet Sales Count], [Measures].[InternetSales-Sales Amount]} ON COLUMNS, {[Product].[Product Line].[Product Line].MEMBERS} ON ROWS FROM [Analysis Services Tutorial] WHERE [Sales Territory].[Sales Territory Country].[Australia]"
result2 <- execute2D(ocs, mdx)
SQL Server Management Studio で MDX ビルダーを使ってクエリを定義し、MDX 文字列を保存した場合、次に示すように、軸には 0 から始まる番号が付けられます。
SELECT {[Measures].[Internet Sales Count], [Measures].[Internet Sales-Sales Amount]} ON AXIS(0),
{[Product].[Product Line].[Product Line].MEMBERS} ON AXIS(1)
FROM [Analysis Services Tutorial]
WHERE [Sales Territory].[Sales Territory Country].[Australia]
それでも、事前定義された MDX 文字列としてこのクエリを実行できます。 ただし、 axis()
関数を使って R で同じクエリを作成するには、軸に 1 から始まる番号を付け直す必要があります。
2.SSAS インスタンス上のキューブとそのフィールドを調べる
explore
関数を使ってキューブ、ディメンション、またはメンバーのリストを取得し、クエリの作成で使うことができます。 これは、他の OLAP 参照ツールにアクセスできない場合、またはプログラムで MDX クエリを操作または作成する場合に便利です。
指定した接続で使用可能なキューブのリストを取得するには
表示権限のあるインスタンス上のすべてのキューブまたはパースペクティブを表示するには、 explore
への引数としてハンドルを渡します。
重要
結果の最後にあるのはキューブではありません。TRUE は、メタデータ操作が成功したことを示しているだけです。 無効な引数を渡すとエラーがスローされます。
cnnstr <- "Data Source=localhost; Provider=MSOLAP; initial catalog=Analysis Services Tutorial"
ocs <- OlapConnection(cnnstr)
explore(ocs)
結果 |
---|
Analysis Services Tutorial |
Internet Sales |
Reseller Sales |
Sales Summary |
[1] TRUE |
キューブ ディメンションのリストを取得するには
キューブまたはパースペクティブのすべてのディメンションを表示するには、キューブまたはパースペクティブの名前を指定します。
cnnstr <- "Data Source=localhost; Provider=MSOLAP; initial catalog=Analysis Services Tutorial"
ocs \<- OlapConnection(cnnstr)
explore(ocs, "Sales")
結果 |
---|
顧客 |
Date |
リージョン |
指定したディメンションと階層のすべてのメンバーを取得するには
ソースを定義してハンドルを作成した後、取得するキューブ、ディメンション、および階層を指定します。 返される結果の項目で前に -> が付いているものは、前のメンバーの子を表します。
cnnstr <- "Data Source=localhost; Provider=MSOLAP; initial catalog=Analysis Services Tutorial"
ocs <- OlapConnection(cnnstr)
explore(ocs, "Analysis Services Tutorial", "Product", "Product Categories", "Category")
結果 |
---|
Accessories |
Bikes |
Clothing |
コンポーネント |
-> Assembly Components |
-> Assembly Components |