推奨事項用の代替データフローの設定
この記事では、代替データフローを使用して推奨事項サービスにデータを提供し、環境を構成する方法について説明します。
既定のデータフローと代替データフローとの比較
次の図は、環境内の既定データフローを示しています。
次の図は、エンティティ ストア同期バッチ ジョブが代替データフロー ステップに置き換えられる代替データフローを示しています。
前提
この記事では、環境に対するレコメンデーション サービスが既に有効になっていると仮定しています。 詳細については、製品レコメンデーションの有効化 を参照してください。
Microsoft Azure Data Lake Storage アカウントでファイルとフォルダーを操作する場合は、次の操作を行います。
- Azure Web ポータル インターフェイスまたは Azure Storage Explorer アプリケーションのいずれかを使用できます。
- ファイルやフォルダーを操作する際の開始点は、使用している環境 URL に一致する名前の付いたフォルダーの下にある dynamics365-financeandoperations コンテナーにあります。
- サンドボックス環境の名前が MyUAT の場合、環境ベース URL は
myuat.sandbox.operations.dynamics.com
です。 - 同じストレージ アカウントに複数の環境が接続されている場合、各環境には独自のルート フォルダーが用意されます。
必要条件
代替データフロー アプローチを実装する前に、以下の前提条件を満たす必要があります:
Microsoft Power Platform の設定
Microsoft Power Platform を設定するには、Microsoft Power Platform 統合を有効にする の手順に従います。
Data Lake アドインへにエクスポート機能をインストールする
[Data Lake にエクスポート] アドインをインストールするには、Azure Data Lake へのエクスポート アドインのインストールの手順に従ってください。
メモ
構成値は、次の手順の一部に対して必要なのでメモします。
Dynamics 365 でエクスポートするテーブルの構成
Dynamics 365 から Azure Data Lake Storage へのテーブル同期は 、Data Lake にエクスポート ページで管理 されます。 このページには現在メニュー項目は存在しないため、システム管理者 セキュリティ ロールのユーザーだけが開くことができます。
Dynamics 365 でエクスポートするテーブルを構成するには、次の手順に従います。
Data Lake へのエクスポート ページを開くには、次の例に示すように、環境の基本 URL に文字列
?mi=DataFeedsDefinitionWorkspace
を追加します。https://<environment-URL>/?mi=DataFeedsDefinitionWorkspace
Data Lake へのエクスポート ページで、この記事のRetailSales キューブ テーブルの一覧 セクションに一覧表示されているテーブルをコピーします。
システム名 列で、フィルター オプションの一覧を展開します。
フィルター タイプについては、次の値のいずれか を選択します。 その後、テキスト ボックスにカーソルを置き、Data Lake へエクスポート ページからコピーしたテーブルの一覧を貼り付けます。
フィルタ オプションの一覧の下部で、適用 を選択します。
グリッド内のすべての行を選択し、アクティブにする を選択します。
メモ
次の手順に進む前に、すべての行のステータスを 実行中 に更新する必要があります。 必要に応じて、エラーのトラブルシューティングと解決を行います。
Synapse ワークスペースを作成する
まだない場合に Synapse ワークスペースを作成するには、クイック スタート: Synapse ワークスペースを作成するの手順に従ってください。
Azure リソースを整理するには、Data Azure Storage アカウントと Synapse ワークスペースを Azure のリソース グループにまとめることをお勧めします。 [Data Lake へのエクスポート] アドインをインストールした時に作成したストレージ アカウントを再使用できます。
レコメンデーション データ処理用に Synapse でデータベースを作成する
Common Data Model ユーティリティ コンソール アプリケーション (CDMUtil_ConsoleApp) を使用して、データベースを Syapse ワークスペースで作成し、Data Lake Storage の Common Data Model テーブルから自動入力します。 拡張機能がある場合は、開発環境では Common Data Model ユーティリティをデータベースと併用することお勧めします。
メモ
次の手順では、RetailSales キューブに拡張データが追加されません。
Synapse でデータベースを作成するには、次の手順に従います。
Dynamics-365-FastTrack-Implementation-Assets GitHub に移動し、手順に従って CDMUtilConsoleApp.zip ファイルをダウンロードします。
zip ファイルをローカル フォルダーに展開します。
CDMUtil_ConsoleApp.dll.config ファイルをテキスト エディタで開き、次の値を更新します。
テナント ID 値 (Azure テナント ID) を設定します。
アクセス キー 値 (Data Storage Storage アカウントのアクセス キー) を設定します。
- Azure ポータルで、ストレージ アカウントを開きます。
- ページの左側にあるメニューで、アクセス キー を選択します。
- ページ上部で、キーの表示 を選択します。
- 2 つのキー フィールドのいずれかのコピー ボタンを選択し、構成ファイルの二重引用符の間に値を貼り付けます。
Azure Data Lake Storage で、ManifestURL の値を Tables.manifest.cdm.json ファイルの URL に設定します。 URL を取得するには、Azure ポータルでファイルを参照し、ビューの右側の省略記号 (...) を選択し、プロパティ を選択します。 URL は、概要 タブに表示される最初のプロパティです。
TargetDbConnectionString の値を、Synapse ワークスペースの組み込みサーバーレス SQL プールの接続文字列に設定します。
- Synapse ワークスペースで、管理 タブを選択します。
- サブメニューで、SQL プール を選択します。
- プールのプロパティを表示するには、組み込み型 という名前を選択します。
- プロパティ ダイアログ ボックスで、使用する ADO.NET 接続タイプを選択します。 その後、接続文字列の値をコピーし、構成ファイルの二重引用符の間に貼り付けます。
メモ
データベースを作成するためのアクセス許可が必要です。 使い易さのために、組み込みの sqladminuser 管理者アカウントを使用することができます。
ProcessEntities ノードのコミットを 解除し、その値を true に設定します (たとえば
<add key="ProcessEntities" value ="true"/>
)。
CDMUtil_ConsoleApp.dll.config ファイルを保存して閉じます。
EntityList.json ファイルを /Manifest ディレクトリにコピーします。
コマンド プロンプト ウィンドウで、cdmutil_consoleapp.exe コマンドを実行します。
メモ
出力を確認する際、35 のエンティティ/ビュー、少なくとも 75 のテーブルがあり、かつエラーがない必要があります。
Data Lake RetailSales Aggregate Measurements ディレクトリの準備
現在の RetailSales キューブ データを Data Lake Storage からバックアップする
現在の RetailSales キューブ データをバックアップする最も簡単な方法は、Data Retail Storage RetailSales-backup などから RetailSales ディレクトリの名前を変更することです。 この方法では、後からトラブルシューティングを行う必要がある場合に備えて、既存のデータを保持します。
/RetailSales キューブ フォルダーは次の場所にあります。
<storage-account>/dynamics365-financeandoperations/<environment-url (for example, myuat.sandbox.operations.dynamics.com)>/AggregateMeasurements/RetailSales
新しい RetailSales フォルダーの作成とモデル ファイルのアップロード
新しい RetailSales ディレクトリを作成し、model.json ファイルを Data Lake Storage にアップロードするには、次の手順に従います。
- 前のディレクトリと同じレベルで新しい空のディレクトリを作成し、そのディレクトリに RetailSales という名前を付けます。
- 新しいディレクトリに model.json ファイルをアップロードします。
RetailSales キューブ データをコピーするパイプラインの作成
パイプラインは RetailSales キューブ ビューを読み取り、データを Data Lake Storageの .csv ファイルにエクスポートします。
パイプラインを作成して RetailSales キューブ データをコピーするには、次の手順に従います。
- Synapse ワークスペースで、統合 タブを選択します。
- プラス記号 (+) を選択し、パイプライン テンプレートからインポート を選択します。
- ExportRetailSalesCubeViews.zip ファイル をダウンロードして選択します。
- SQL データベースにリンクされたサービスを選択します。
- ストレージ アカウントにリンクされたサービスを選択します。
- データのコピー ツールを開き、フォルダー パス プロパティを <environment_name>/... に変更します。
パイプラインのテスト実行
パイプラインは、1 つのビューだけを使用してテストすることをお勧めします。 RetailSales_RetailMediaTemplateView ビューは、含まれる行が 10 行未満なのでうまくいきます。
パイプラインを定期スケジュールで実行するようにスケジュールする
パイプラインを実行するたび、Azure の消費が発生します。 実行は 48 時間以上の間隔でスケジュールすることをお勧めします。 データをすぐに同期する必要がある場合は、パイプラインをいつでも手動で実行できます。
Dynamics 365 から Data Lake Storage への同期のテーブル リスト
次のテーブルのリストは、RetailSales キューブ全体に必要なすべてのテーブルのサブセットです。 RetailSales キューブのビューのうち 15 つだけがレコメンデーション サービスで使用され、必要なテーブルのリストがそれに従ってフィルター処理されています。
RetailSales キューブ テーブルのリスト
- BICalendarOffsets
- BIDateDimension
- BIDateDimensionValue
- カタログ
- CatalogProduct
- CatalogProductCategory
- CustInvoiceJour
- CustInvoiceTrans
- CustTable
- DataArea
- DimensionAttributeValueCombination
- DimensionAttributeValueSet
- DirPartyTable
- EcoResCategory
- EcoResCategoryHierarchy
- EcoResCategoryHierarchyRole
- EcoResColor
- EcoResConfiguration
- EcoResProduct
- EcoResProductCategory
- EcoResProductTranslation
- EcoResSize
- EcoResStyle
- HcmWorker
- InventDim
- InventDimCombination
- InventItemGroup
- InventItemGroupItem
- InventItemSetupSupplyType
- 在庫テーブル
- InventTrans
- LogisticsAddressCountryRegion
- LogisticsAddressCountryRegionTranslation
- LogisticsLocation
- LogisticsPostalAddress
- OMHIERARCHYPURPOSE
- RetailAssortmentLookup
- RetailAssortmentLookupChannelGroup
- RetailChannelProfile
- RetailChannelProfileProperty
- RetailChannelTable
- RetailChannelTableExt
- RetailConnDatabaseProfile
- RetailCustInvoiceJourTable
- RetailCustTable
- RetailMediaTemplate
- RetailOfflineProfile
- RetailPeriodicDiscount
- RetailRecoListConfigurationParameters
- RetailSalesTaxOverrideGroup
- RetailSharedParameters
- RetailSpecialCategoryMember
- RetailTenderTypeCardTable
- RetailTenderTypeTable
- RetailTerminalTable
- RetailTmpProductMedia
- RetailTransactionDiscountTrans
- RetailTransactionPaymentTrans
- RetailTransactionPaymentTransExt
- RetailTransactionSalesTrans
- RetailTransactionSalesTransExt
- RetailTransactionTable
- SalesLine
- SalesTable
- SystemParameters
- RETAILCATALOGINTERNALORG
- RETAILGROUPMEMBERLINE
- RETAILINTERNALORGANIZATION
- RETAILSPECIALCATEGORYPRODUCT
- RETAILPRODUCTCATEGORY
- ECORESCONFIGURATION
- DIMENSIONATTRIBUTE
- DIMENSIONATTRIBUTEVALUESET
- DIMENSIONHIERARCHY
- DIMENSIONHIERARCHYINTEGRATION
- DIMENSIONHIERARCHYLEVEL
- DIMENSIONPARAMETER
- OMExplodedOrganizationSecurityGraph
Synapse パイプラインに渡すパラメーターのリストを表示します
次のコンマ区切りリストには、パイプラインで "選択" 操作が実行される RetailSales キューブ ビューが含まれます。 結果は Data Lake Storage にコピーされます。
RetailSales_RetailAssortmentRulesView,RetailSales_RetailChannelNavigationHierarchiesView,RetailSales_RetailChannelNavigationHierarchyCatalogProductsView,RetailSales_RetailChannelNavigationHierarchyCategoryNodesView,RetailSales_RetailChannelNavigationHierarchyCategoryProductsView,RetailSales_RetailMediaBaseUrlChannelView,RetailSales_RetailMediaRelativeUrlProductView,RetailSales_RetailMediaTemplateView,RetailSales_RetailOptOutCustomersView,RetailSales_RetailProductCategory,RetailSales_RetailProductTransaction,RetailSales_RetailProductVariantDimensionsView,RetailSales_RetailRecoListConfigurationParametersView,RetailSales_RetailRecoListsSharedParametersView,RetailSales_RetailEcoResProductTranslation
重要
パイプライン パラメーターは、単一のコンマで区切られたビュー名のリストである必要があります。 スペースまたはライン フィードは含めることはできません。
環境固有の修正
RETAILCHANNELVIEW 修正
RETAILCHANNELVIEW には、「小売チャンネル」 タイプの組織を表すハード コードされた整数が含まれています。 タイプの実際値は、環境から環境、またはテナントからテナントに変更できます。
CREATE OR ALTER VIEW [dbo].[RETAILCHANNELVIEW]
AS
SELECT T1.RECID AS RECID1,
T1.STOREAREA AS STOREAREA,
T1.OMOPERATINGUNITID AS OMOPERATINGUNITID,
T1.DEFAULTCUSTACCOUNT AS DEFAULTCUSTOMER,
T1.RETAILCHANNELID AS RETAILCHANNELID,
T1.CHANNELTYPE AS CHANNELTYPE,
T1.PARTITION AS PARTITION,
T1.RECID AS RECID,
T2.OMOPERATINGUNITNUMBER AS OMOPERATINGUNITNUMBER,
T3.NAME AS NAME
FROM dbo.RETAILCHANNELTABLE AS T1 CROSS JOIN dbo.DIRPARTYTABLE AS T2 CROSS JOIN dbo.DIRPARTYTABLE AS T3
WHERE ((((T1.OMOPERATINGUNITID = T2.RECID)
)
AND ((T2.RECID = T3.RECID)
))
AND T2.INSTANCERELATIONTYPE IN (8363));
ハードコード化された整数を更新するには、次の手順を実行します。
Dynamics 365 で、オンライン チャンネルの ChannelID 値を参照します。
Synapse データベースに関連付けられた SQL Server Management Studio (SSMS) のインスタンスで、次のクエリを実行します。
select INSTANCERELATIONTYPE, NAME, NAMEALIAS, * from dbo.DIRPARTYTABLE where RECID IN (select OMOPERATINGUNITID from dbo.RETAILCHANNELTABLE where RETAILCHANNELID = <channelID>)
1 列目 (INSTANCERELATIONTYPE) から値をコピーし、ビュー定義に貼り付けます。
トラブルシューティング
パイプライン タスク失敗
CopyData タスクに対して 15 件のパイプライン タスクを実行する必要があります。 実行が失敗した場合は、すべての依存 SQL オブジェクトが存在し、クエリが実行されることを検証する必要があります。 すべての依存関係にアクセスする最も簡単な方法は、SSMS を使ってデータベースに接続する方法です。 その後、ビューを選択して保留 (または右クリック) し、新しいウィンドウに対して CREATE を生成する を選択できます。
エラー メッセージには次のテキストが含まれている場合があります。
- エラー : "ソース" 側でエラーが発生しました
- 外部ファイルのエラー処理 : 「最大エラー カウント」。
- /RetailSales/RetailSales_xxxxxx
シナリオ例
この例では、タスク RetailSales_RetailProductCategory が失敗し、「Max errors count」 というエラーが表示されます。
エラーをデバッグするには、次の手順に従います。
テキスト エディタ (Visual Studio Code など) で EntityList.json ファイルを開きます。
RetailSales_RetailProductCategory のビュー定義を見つけます。
CREATE VIEW [dbo].[RetailSales_RetailProductCategory] AS SELECT 0 AS ROW_UNIQUEKEY ,CATEGORY AS CATEGORYID ,PRODUCT AS PRODUCTID ,PRODUCTNAME ,CATEGORYNAME ,PARENTCATEGORY AS PARENTCATEGORYID ,PARTITION ,RECID FROM RetailProductCategoryView
このビューは RetailProductCategoryView* という他の 1 つのビューにのみ依存します。 RetailProductCategoryView のビュー定義を見つけます。
CREATE VIEW [DBO].[RETAILPRODUCTCATEGORYVIEW] AS SELECT T1.CATEGORY AS CATEGORY, T1.PRODUCT AS PRODUCT, T1.PARTITION AS PARTITION, T1.RECID AS RECID, T2.PRODUCTNAME AS PRODUCTNAME, T2.PARTITION AS PARTITION#2, T3.NAME AS CATEGORYNAME, T3.PARENTCATEGORY AS PARENTCATEGORY, T3.PARTITION AS PARTITION#3 FROM RETAILPRODUCTCATEGORY T1 CROSS JOIN ECORESPRODUCTTRANSLATIONS T2 CROSS JOIN RETAILCATEGORYEXPANDED T3 WHERE((( T1.PRODUCT = T2.PRODUCT) AND ( T1.PARTITION = T2.PARTITION)) AND (( T1.CATEGORY = T3.RECID) AND ( T1.PARTITION = T3.PARTITION)))
このビューは、RETAILPRODUCTCATEGORY、RETAILRESPRODUCTTRANSLATIONS、および RETAILCATEGORYEXPANDED の 3 つのビューに依存します。 これらの各ビューの定義を検索し、その依存関係を一覧表示します。 すべての従属ビューが見つけるまでこのまま続行します。
次に、依存関係ツリーの順序の全体の一覧を示します。 13 回のビューは検証する必要があります。
RetailSales_RetailProductCategory
RetailProductCategoryView
RETAILPRODUCTCATEGORY
ECORESPRODUCTCATEGORY
ECORESCATEGORYHIERARCHYROLE
RETAILSPECIALCATEGORYPRODUCT
- ECORESPRODUCT
- RETAILGROUPMEMBERLINE
- RETAILSPECIALCATEGORYMEMBER
ECORESPRODUCTTRANSLATIONS
- ECORESPRODUCT
- ECORESPRODUCTTRANSLATION
- SYSTEMPARAMETERS
RETAILCATEGORYEXPANDED
- ECORESCATEGORY
- ECORESCATEGORYHIERARCHYROLE
Excel で次の 13 select count(*) from <view_name> ステートメントを作成します。 これらのステートメントを SQLS で実行し、結果をテキストに送信します。 その後、結果までスクロールして、一部のビューが失敗したかどうかを確認します。 最初のエラーは、少なくとも 1 つのビューが失敗したことを示しています。
select count(*) from RetailProductCategoryView select count(*) from RETAILPRODUCTCATEGORY select count(*) from ECORESPRODUCTCATEGORY select count(*) from ECORESCATEGORYHIERARCHYROLE select count(*) from RETAILSPECIALCATEGORYPRODUCT select count(*) from ECORESPRODUCT select count(*) from RETAILGROUPMEMBERLINE select count(*) from RETAILSPECIALCATEGORYMEMBER select count(*) from ECORESPRODUCTTRANSLATIONS select count(*) from ECORESPRODUCTTRANSLATION select count(*) from SYSTEMPARAMETERS select count(*) from RETAILCATEGORYEXPANDED select count(*) from ECORESCATEGORY
表示している情報を検証する 1 つの方法として、ルート依存のビューを作成して、ビュー定義を SSMS で生成します。 その後、r.filepath という名前の Azure Data Lake ファイル列があることを確認します。 この列が存在する場合、検査中のビューが Data Lake Storage のデータを読み取っていることを示します。