アップグレードした AX 2012 R3 販売キューブのエンティティ格納への移行
このチュートリアルでは、アップグレードされた Microsoft Dynamics AX 2012 R3 キューブ スキーマを、財務と運用アプリケーションのエンティティ格納に移行します。 例として、Dynamics AX 2012 R3 に含まれていた販売キューブを使用します。
エンティティ格納は、次の図に示すように、ほぼリアルタイムの Microsoft Power BI 統合シナリオをサポートします。 エンティティ格納と Power BI 統合の概要については、「エンティティ格納と Power BI の統合」を参照してください。
2016 年 5 月および 2016 年 11 月の更新プログラムに含まれる Power BI の新機能
このチュートリアルでは、Dynamics 365 for Operations の 2016 年 5 月以降の更新プログラムが必要です。 このチュートリアルでは、次の新しい機能を使用します。
- エンティティ格納で集計測定をステージングし、Dynamics AX のデータを更新します。 メモリ内リアルタイムの集計測定値には、以下のような場合に、このオプションの方を選択する可能性があります:
- Dynamics AX 2012 キューブをアップグレードします。
- 集計の測定は非常に大規模です。
- データの新しさ (待機時間) は、数分から数時間まで報告することができます。
- 定期的な更新をスケジュールするには、バッチ フレームワークを使用します。 このリリースでは、完全な更新のみが有効になります。
- 開発者/テスト環境で Power BI desktop を使用してレポートを作成します。
- Power BI コンテンツを作成するときに、直接クエリ オプションを活用できます。 たとえば、データ更新のメカニズムとして OData に依存せず、大きなモデルを作成できます。
- Lifecycle Services (LCS) を使用してレポートを開発環境から運用環境に移行します。
- パートナーまたは ISV として、Power BI コンテンツを LCS ソリューションの一部として顧客に配布することができます。
- 11 月の更新 (プラットフォーム リリース 1611) 以降を使用している場合、このドキュメントのいくつかの手順は、エンティティ ストアを更新するプロセスの一部です。手動で実行する必要はありません。
アップグレードされた集計の測定プロパティの変更
コード アップグレード プロセスの一環として、Dynamics AX 2012 のアプリケーション オブジェクト ツリー (AOT) からの分析サービス プロジェクトを新しい集計測定メタデータ形式に移行することができます。
Visual Studio を起動し、アプリケーション スイートで新しいプロジェクトを作成します。
メモ
モデルを作成し、カスタマイズされた集計測定をそのモデルに含めることができます。 詳細については、 拡張機能およびオーバーレイによるカスタマイズ を参照してください。
アプリケーション エクスプローラを開きます。 分析>分析視点>集計の測定の順に移動します。 現在のバージョンに同梱されている測定だけでなく、Dynamics AX 2012 R3 からアップグレードされた集計の測定のセットが表示されます。
SalesCube を選択します。 右クリックし、プロジェクトで複製 を選択します。
SalesCubeCopy という名前の集計の測定がプロジェクトに追加されます。
この測定値の名前を変更します。 ソリューション エクスプローラーで、SalesCubeCopy を選択します。 右クリックし、名前の変更 を選択します。 SalesCubeV2 という新しい名前を入力します。
Aggregate measurement designer を起動するには、SalesCubeV2 をダブルクリックします。 Dynamics AX 2012 から移行された集計の測定の構造体を確認します。
Dynamics AX 2012 の営業キューブは、販売に関連する広範な分野を包含していました。 この場合、アップグレードしたメタデータを使用してより小規模で焦点を絞った Power BI モデルを作成しましょう。 販売注文明細行のメジャー グループを展開し、メジャー リストおよび分析コードの参照を確認します。
メモ
モデリング機能を活用することで、このモデルをすばやく機能拡張することができます。 改善の提案:
- メジャー グループ (または分析コード) をモデル化するために使用されたビュー/テーブルをエンティティに置き換えます。 基になるビューを使用してエンティティをモデリングして、対応するエンティティでビューを置き換えることができます。 これにより、インクリメンタル リフレッシュおよびセキュリティなど、今後登場する機能を活用できます。
- 属性ノードに対応するフィールドを追加することで、不要な分析コードの参照を削除します。 たとえば、メジャー グループのサイズフィールドが十分に説明され、サイズの分析コード参照は削除されます。 これにより、クエリのランタイム パフォーマンスとリフレッシュ時間が向上します。
集計測定デザイナーで SalesCubeV2 ルート ノードを選択します。 右クリックし、プロパティ を選択します。
アップグレード中に、集計の測定はレガシ プロパティ フラグ SSASCube に設定されます。 サポートされる使用法の 2 つのタイプのいずれかに、このプロパティを変更する必要があります。 以前は、InMemoryRealTime は集計測定値の使用方法としてサポートされていました。 StagedEntityStore は新しい使用タイプとしてサポートされています。
メモ
埋め込み BI シナリオおよび Power BI 統合に集計の測定を使用する場合は、用途プロパティを InMemoryRealTime に変更します。 Power BI または Cortana Intelligence との統合に対してのみ集計測定を使用している場合は、StagedEntityStore を選択します。
プロジェクトを保存します。 ソリューション エクスプローラーでプロジェクトを選択し、リビルド を選択します。
再構築操作を完了した後、プロジェクトを保存し、Visual Studio を閉じます。 これで開発作業は完了です。 レポート作成者またはパワー ユーザーとしてレポートを作成します。
エンティティ格納を更新
管理者は、クライアントを使用して集計測定の更新をコンフィギュレーションできます。
- Dynamics AX クライアントを起動して、システム管理>設定>エンティティ格納に移動します。 エンティティ格納 フォームには、エンティティ格納に配置するために使用できる集計測定の一覧が表示されます。
- 営業キューブ (Dynamics AX 2012 からアップグレードされた) がエンティティ格納への配置に使用できないことを確認します。 SalesCubeV2、前の手順で作成したものをエンティティ格納に展開できます。
- リストから SalesCubeV2 を選択し、更新 ボタンをクリックします。 更新 ダイアログ ボックスが表示されます。 バックグラウンドで実行タブを展開します。
- タスクの説明 フィールドにわかりやすい名前を入力します。 必要に応じて、定期的なアイテム タブを選択し、1 回限りの更新ではなく定期的なスケジュールを作成できます。 OK をクリックします。
- エンティティ ストア内の集計測定値をリフレッシュするためのバッチ ジョブが作成されます。
Power BI desktop を使用して都道府県別売上レポートの作成
このステップでは、Microsoft Power BI Desktopからダウンロードできる Power BI desktop ツールをインストールする必要があります。
Power BI desktop を起動します。 更新を適用することが必要な場合があります。 ウェルカム ページが表示されます。 データの取得をクリックします。
または、Power BI desktop が起動したとき、ホーム タブのデータの取得>SQL Server を選択します。
SQL Server データベース ダイアログ ボックスで、サーバー名とエンティティ ストア データベースの名前を入力します。 開発環境を配置する場合は、“.” を入力できます。 サーバー名として、および AxDW をデータベースとして。 テスト環境で作業している場合、システム管理者からこれらのパラメータを取得する必要があります。
DirectQuery オプションを選択します。 この練習では、エンティティ格納に直接実行される Power BI レポートを作成します。 インポート オプションを使用した場合、Power BI ではエンティティ格納のデータがキャッシュされるため、Power BI モデルを定期的に更新する必要があります。 エンティティ格納を使用して書かれたレポートでは、インポート モードは現在サポートされていません。 OK をクリックします。
次に、ナビゲーター ダイアログ ボックスが表示されます。 ナビゲーターで、レポートの対象となるテーブルとビューをエンティティ格納から選択できます。 検索ボックスで販売を入力します。 以前に作成された SalesCubeV2 集計測定に関連するエンティティがフィルタリングされます。
メモ
エンティティ ストアは作成された集計の測定をステージします。 それぞれの集計測定内のエンティティには接頭語が付けられて別々のテーブルとして保管されますが、Power BI desktop を使用すると複数の集計測定からのデータを結合することができます。
都道府県別の売上を表示するレポートを作成します。 ナビゲーターから SalesCubeV2_Customer および SalesCubeV2_CustomerInvoices を選択し、読み込みをクリックします。
選択したエンティティ (右端) にフィールドが存在する Power BI デザイナーが、使用可能な視覚化とともに表示されます。
顧客と請求書をリンクする代理キーを作成する (2016 年 11 月アップデート以前のプラットフォーム バージョンに適用)
メモ
代理キーは、エンティティ格納にステージングされる集計測定で生成されます。 Power BI desktop では、複数のフィールド (複合キーとも呼ばれます) を使用してテーブル結合を関連付けることができません。 SalesCubeV2_Customer エンティティでは、代理キー (AX RecID など) が定義されていません。 次に、請求書に顧客エンティティを関連付けできる代理キーを作成します。
SalesCubeV2_CustomerInvoices エンティティの横にある省略記号 (...) アイコンを選択します。 右クリックし、新しい列 を選択します。
フォーミュラ エディタウィンドウに次の式を入力します。
FKCustomer = CONCATENATE(CONCATENATE(SalesCubeV2_CustomerInvoices[DATAAREAID], "-"), SalesCubeV2_CustomerInvoices[ORDERACCOUNT])
メモ
フィールド名または関数の最初の数文字を入力すると、エディターに候補フィールドの一覧が表示されます。 これは、先行入力機能と呼ばれます。 この式をコピーして貼り付けるか、タイプ先行機能を使用することができます。
完了すると、式は次のようになるはずです。
新しいフィールド、FKCustomer が SalesCubeV2_CustomerInvoices テーブルのフィールドの一覧に表示されていることに注意します。 このフィールドは 2 つのテーブルを関連付けるために使用されるので、フィールドを右クリックして非表示オプションを選択するとエンド ユーザーから非表示にすることができます。
次に、SalesCubeV2_Customer テーブルに類似したフィールドを作成します。 SalesCubeV2_Customer エンティティの横にある省略記号 (...) アイコンを選択します。 右クリックし、新しい列 を選択します。
フォーミュラ エディタウィンドウに次の式を入力します。
FKCustomer = CONCATENATE(CONCATENATE(SalesCubeV2_Customer[DATAAREAID], "-"), SalesCubeV2_Customer[CUSTOMER])
フィールド FKCustomer が SalesCubeV2_Customer テーブルのフィールドの一覧に表示されていることに注意します。 このフィールドは 2 つのテーブルの関連付けに使用されるため、フィールドを右クリックして非表示オプションを選択するとエンド ユーザーから非表示にすることができます。
請求書および顧客を関連付ける
メモ
エンティティ格納内で既に作成されている代理キーを関連付けることができます。 それ以外の場合は、手動で作成した代理キーを関連付ける必要があります。 次に、SalesCubeV2_CustomerInvoices と SalesCubeV2_Customers のエンティティのリレーションシップを作成します。
- Power BI リボンの関係の管理ボタンをクリックします。 リレーションシップの管理 ダイアログ ボックスが表示されます。 新規ボタンをクリックします。
- 関係の作成ダイアログ ボックスで、SalesCubeV2CustomerInvoices をドロップダウン リストの最初のテーブルとして選択します。 右にスクロールし、関連する列として FKCustomer フィールドを選択します。
- 2 番目のドロップダウン リストで、SalesCubeV2Customer をテーブルとして選択します。 右にスクロールし、関連する列として FKCustomer を選択します。
- この関係を有効にする オプションがまだオンになっていない場合はオンにします。 OK をクリックして続行します。
- 新しく作成されたリレーションシップは リレーションシップの管理 ダイアログ ボックスでわかります。 閉じるボタンをクリックします。
都道府県別売上レポートを作成する
顧客グループによる売上を示すレポートを作成するには、SalesCubeV2_CustomerIncoices テーブルからCustomerInvoiceAmountAccountingCurrency フィールドをドラッグして、Power BI desktop キャンバスにドロップします。 次に、SalesCubeV2_Customer テーブルの CustomerGroupName フィールドを同じグリッドにドラッグします。
グラフの種類をドーナツ グラフに変更します。 次のようなレポートが表示されます。
Power BI desktop を使用して、追加のビジュアルを作成することができます。 保存するとき、ファイルに PBIX 拡張子が付いていることがわかります。
レポートをデスクトップに保存します。
この時点でレポートは (環境のデータで) 完全に機能しており、Power BI desktop を引き続き使用するか、このレポートを PowerBI.com にアップロードしてデータの検索を続行できます。
次に、LCS を使用してこのレポートを運用環境に移行し、運用データとともにこのレポートを表示して、他のユーザーと共有できるようにします。
レポートおよびモデルを公開
レポートとモデルの発行には、Lifecycle Services へのレポートのアップロード、集計単位の運用環境への移行、適切な LCS ライブラリをポイントするためのクライアントの構成、運用環境でのレポートの発行が必要です。
レポートを Lifecycle Services にアップロード
Microsoft Dynamics Lifecycle Services (LCS) は、開発者から運用環境に開発コンポーネントを移行するために使用するツールです。 2016 年 5 月の更新プログラムで、LCS は環境間の PBIX ファイルの移行 (エンティティ格納を使用して作成) をサポートします。
- 開発環境から LCS を起動します。 LCS 環境で、プロジェクトを作成していない場合は、プロジェクトを作成します。
- 右にスクロールし、アセット ライブラリ アイコンを確認します。 アイコンをクリックし、アセット ライブラリを起動します。
アセット ライブラリを使用して、プロジェクトに PowerBI レポート モデル (PBIX ファイル) を実装コンポーネントとして追加できることに注意します。
- プラス記号 (+) を選択し、新しい資産を追加します。
- 名前と説明を入力します。 アップロードをクリックし、前の手順で保存したファイルを探します。
- ファイルを正常にアップロードした後、確定をクリックします。 ファイルが実装アセットとして LCS にアップロードされることを確認します。 LCS は、バージョン管理をサポートして、Power BI レポートをリリースします。 他の実装コンポーネントに対するのと同じ方法で、複数のバージョンを管理してレポートを他環境に公開することができます。 PBIX ファイルを LCS プロジェクト内の資産として追加したため、そのプロジェクトを使用して配備した環境はこのレポートにアクセスできます。
- 必要に応じて、すべてのプロジェクトが共用資産にアクセスできるように、このレポートを発行することができます。 パートナーまたは ISV であり、お客様とこのレポートを共有する場合は、グローバル ライブラリにこの資産を共有し、顧客が資産をそれぞれの LCS プロジェクトにインポートできるようにします。 これを行うには、マイライブラリに保存 オプションを選択します。
集計の測定の運用環境への移行
- 開発環境で修正した集計測定を運用環境に移行する必要があります。 配置可能パッケージを生成の指示に従うことができます。 create-apply-deployable-package.md.
- モデルを正常に公開した後、このチュートリアルのエンティティ ストアを更新セクションの説明している手順に従って実行し、エンティティ ストアはデータを更新できるようにします。
LCS プロジェクトをコンフィギュレーションする
まだ実行していない場合は、環境と LCS プロジェクトを関連付けることで、財務と運用アプリがプロジェクト内の資産を消費できるようにします。
Power BI レポートの配置に使用するインスタンスからクライアントを起動します。 これは通常、データ セットのレポートを表示するテストまたは本番のインスタンスであり、レポート開発者として作業したものとは異なります。
システム管理>設定>システム パラメーターの順に開きます。 ヘルプ タブを選択します。Lifecycle Services のヘルプ構成 ボックスの一覧を使って、PBIX ファイルをアップロードした LCS プロジェクトを選択します。 保存 をクリックします。
メモ
このフォームには、現在のユーザーがアクセスできる LCS プロジェクトのみが表示されます。 このステップが管理者によって実行される場合、管理者がプロジェクトにアクセスする必要があるか、または PBIX コンポーネントが管理者がアクセスできるプロジェクトにインポートする必要があります。
Power BI レポートを運用環境に公開
クライアントからシステム管理>設定>PowerBI の配置の順に開きます。 LCS にアップロードしたファイルが分かります。
売上報告書 ファイルを選択し、メニュー バーで Power BI ファイルの配置オプションを選択します。
メモ
PowerBI.com サービスへの公開に同意するよう求められる場合があります。 同意するには、リンクをクリックしてください。 同意が完了すると、元のブラウザー ウィンドウに戻り、閉じる ボタンをクリックする必要があります。
ファイルを正常に公開した後、Power BI レポートは PowerBI.com サブスクリプションに表示されます。 レポートが運用環境にあるエンティティ格納を現在指さしていることがわかります。
PowerBI.com での継続
管理者またはパワーユーザーは、エンティティ格納を使用して運用環境に Power BI レポートを作成し公開することに成功しています。 Power BI 機能を使用して、いくつかの追加手順を実行することができます。
- 必要に応じて、データセットにレコード レベルのセキュリティを適用して、Power BI での表示が許可されていないデータの表示をユーザーに制限することができます。
- 組織のコンテンツ パックを作成して、グループ内のユーザーの間で共有することができます。
- PowerBI.com インスタンスから、データベース、レポート、およびダッシュボードを、新しいコンテンツパックとして、選択したユーザーのグループにエクスポートすることができます。
- 組織のコンテンツ パックは、データセット レベルで定義した任意のレコード レベルのセキュリティ ルールに従うことに注意してください。
- Power BI タイルまたはレポートを追加することによって、自分のワークスペースをパーソナライズできます。