チャネル データベース 拡張機能
この記事では、チャンネル データベースの拡張方法を説明します Microsoft Dynamics 365 Commerce。
チャネル データベース (チャネル DB) は、オンライン ストアまたは従来型の店舗などの 1 つまたは複数のコマース チャネルからのトランザクションおよびマスター データを保持します。 マスター データは Commerce Data Exchange (CDX) を使用して、バックオフィスからチャネル データベースにプッシュ ダウンされます。 チャネル データベースに格納されたトランザクション データは、CDX を使用して本社に引き戻されます。
この記事では、さまざまなシナリオのチャネル データベースを拡張する方法について説明します。 以下の手順は、Dynamics 365 Finance および Commerce にのみ適用されます。
拡張機能のさまざまなシナリオを説明する前に、チャネル DB 拡張機能の最新の機能拡張を理解することが重要です。
アップグレード時の拡張機能の処理の方法にいくつかの改善を加えました。 以下の環境構成のいずれかを使用することをお勧めします。
- Microsoft Dynamics 365 Finance、エンタープライズ エディション (2017年7月) (アプリケーション更新プログラム5を含む)。
- Microsoft Dynamics 365 Retail 7.2 およびアプリケーション更新プログラム 5 (まもなく利用できます)
- Microsoft Dynamics 365 Retail 7.3 (アプリケーション更新プログラム 5 を含みます)
- Microsoft Dynamics 365 Finance 7.3 (アプリケーションの更新5を含む)。
詳細については、チャンネルの事前に拡張された列を参照してください。
Ext スキーマ
Finance と Commerce では、拡張機能をサポートするため、ext スキーマと呼ばれる新たなスキーマを導入しました。 以前のバージョンでは、チャネル DB に拡張機能を追加する場合、CRT または AX スキーマに追加していました。 Finance と Commerce のいずれでも、CRT、AX や DBO スキーマを変更することはできません。 すべての変更は ext スキーマで行う必要があります。 CRT または AX スキーマの何かを変更すると、Lifecycle Services (LCS) での展開に失敗します。 CRT、AX、および DBO スキーマを変更する権限がありません、というエラーが表示されます。 拡張機能には、展開の過程で CRT、AX、や DBO のスキーマ定義を読み取るアクセス許可がありません。CRT、AX、や DBO のスキーマ定義を読み取る拡張スクリプトにクエリを含めないでください。
メモ
いずれかのチャネル DB フィールドの長さを伸ばす場合は、LCS で拡張機能の要求を作成し、EDT の伸長または小数点以下の精度を高める必要があります。 変更はチャネル DB に自動的にプッシュされません。また、拡張子には、チャネル DB - CRT、AX、または DBO スキーマで何かを変更または修正するための許可は付与されていません。 CRT または AX スキーマの何かを変更すると、LCS での展開が失敗します。
チャネル DB 拡張機能のためのベスト プラクティス
- CRT、AX、または DBO スキーマのいずれも変更しないでください。 すべての拡張シナリオで ext スキーマを使用します。
- 使用可能な場合は、CRT、AX、または DBO オブジェクトからチャネル データベース コンポーネントに直接アクセスするのではなく、Commerce Runtime データ サービスを介してデータを取得することをお勧めします。
このようにしない
以下はユーザーがしてはいけないことの例です。 代わりに、主キーの値を取得するために CRT データ サービスを使用してから、拡張テーブルに挿入するために主キーの値を使用する必要があります。
MERGE INTO [ax].RETAILCUSTPREFERENCE --DONT access ax schema object
USING (SELECT DISTINCT
tp.PARENTRECID, tp.PROPERTYVALUE as [EMAILOPTIN], ct.ACCOUNTNUM, ct.DATAAREAID
FROM @TVP_EXTENSIONPROPERTIESTABLETYPE tp
JOIN [ax].CUSTTABLE ct on ct.RECID = tp.PARENTRECID --DONT access ax schema object
WHERE tp.PARENTRECID <> 0 and tp.PROPERTYNAME = 'EMAILOPTIN') AS SOURCE
ON [ax].RETAILCUSTPREFERENCE.RECID = SOURCE.PARENTRECID
and [ax].RETAILCUSTPREFERENCE.DATAAREAID = SOURCE.DATAAREAID --DONT access ax schema object
and [ax].RETAILCUSTPREFERENCE.ACCOUNTNUM = SOURCE.ACCOUNTNUM
WHEN MATCHED THEN
UPDATE SET [EMAILOPTIN] = source.[EMAILOPTIN]
WHEN NOT MATCHED THEN
INSERT
(
RECID
,DATAAREAID
,EMAILOPTIN
,ACCOUNTNUM
)
VALUES
(
SOURCE.PARENTRECID
,SOURCE.DATAAREAID
,SOURCE.EMAILOPTIN
,SOURCE.ACCOUNTNUM
);
SELECT @i_Error = @@ERROR;
IF @i_Error <> 0
BEGIN
SET @i_ReturnCode = @i_Error;
GOTO exit_label;
END;
このようにしない
- CRT、AX、またはDBO スキーマに新しい拡張テーブル、ビュー、または手順を作成しないでください。 すべての拡張コンポーネントは、ext スキーマで実行する必要があります。
- ext スキーマでは、CRT、AX、またはDBO スキーマのデータ型を使用しないでください。 ext スキーマのカスタム タイプを作成して使用してください。
- ビュー、手順、関数、またはデータベース コンポーネントを修正しないでください。
- 可能な場合は、拡張機能からのデータベース コンポーネントへのアクセスや呼び出しは回避してください。 代わりに、CRT データ サービスを使用してデータを取得します。 データ サービスを使用する利点は、今後データベース スキーマに重大な変更が行われた場合でも、SLA まで継続的にサポートされることです。 ただし、必要なデータを公開しない CRT データ サービスのインスタンスもあります。 このような場合、チャネル データベース コンポーネントに結合するビューを作成することによって、このデータにアクセスすることができます。 ビューの作成は、CRT 拡張機能を使用してメモリ内で行うのではなく、データベース レベルで必要な形式のデータを構築する強力なツールになります。
- DBO スキーマ オブジェクトは Commerce Scale Unit の配置では使用できないため、拡張スクリプトから dbo.objects にはアクセスしないでください。
CREATE VIEW [ext].[CONTOSORETAILSTOREHOURSVIEW] AS
(
SELECT
sdht.DAY,
sdht.OPENTIME,
sdht.CLOSINGTIME,
sdht.RECID,
rst.STORENUMBER
FROM [ext].[CONTOSORETAILSTOREHOURSTABLE] sdht
INNER JOIN [ax].RETAILSTORETABLE rst ON rst.RECID = sdht.RETAILSTORETABLE
)
拡張機能の追加
拡張テーブルを作成している場合にデータをバックオフィスに同期するには、テーブルの主キーおよびクラスター化されたインデックスが拡張テーブルのバックオフィス テーブルと同じである必要があります。そうでない場合 CDX 同期は失敗します。 拡張テーブルからバックオフィスにデータをプルする必要がある場合は、拡張テーブルにREPLICATIONCOUNTERFROMORIGIN ID 列 (
[REPLICATIONCOUNTERFROMORIGIN] [int] IDENTITY(1,1) NOT NULL,
) が含まれている必要があります。 REPLICATIONCOUNTERFROMORIGIN フィールドを唯一の固有フィールドにすることはできません。すべての拡張テーブルの列には、NOT NULL の制約を適用する必要があります。 更新の過程で、列の値が空白で更新され、NULL の値が正しく処理されない場合は、 CRT でランタイムの例外処理が発生する可能性があります。
すべての拡張機能テーブルは UserRole および DeployExtensibilityRole にアクセス許可を付与する必要があります。
--Tables: GRANT SELECT, INSERT, UPDATE, DELETE ON OBJECT::[ext].[RETAILCUSTPREFERENCE] TO [UsersRole] GO GRANT SELECT, INSERT, UPDATE, DELETE ON OBJECT::[ext].[RETAILCUSTPREFERENCE] TO [DeployExtensibilityRole] GO --Stored procedures: GRANT EXECUTE ON [ext].[EXTSTOREDPROCEDURE] TO [UsersRole]; GO GRANT EXECUTE ON [ext].[EXTSTOREDPROCEDURE] TO [PublishersRole]; GO GRANT EXECUTE ON [ext].[EXTSTOREDPROCEDURE] TO [DeployExtensibilityRole]; GO
テーブルがバックオフィスからデータを送受信する場合は、DataSyncUsersRole のアクセス許可を付与します。
GRANT SELECT, INSERT, UPDATE, DELETE, ALTER ON OBJECT::[ext].[EXTTABLENAME] TO [DataSyncUsersRole] GO
たとえば、 ContosoRetailTransactionTable などのように、常にテーブルに接頭語を付けると、他のカスタマイズとの競合を回避できます。
属性
顧客、顧客注文、現金売りトランザクション、およびコール センター注文の属性をサポートするために、バックオフィスの属性フレームワークを拡張しました。
顧客属性
新しい顧客属性フレームワークでは、構成を使用して、POS またはバックオフィス内の顧客追加/編集画面または顧客詳細画面に新しいフィールドを追加することができます。 コマース パラメーターで顧客属性グループを構成した後、POS やバックオフィスはコードの変更やカスタマイズを行わずに新しい属性を自動的に表示します。 画面レイアウト設計者は、取引画面 (顧客 パネル) に顧客属性を表示するようにも設定されます。
注文属性
属性フレームワークは、現金売りトランザクション、顧客の注文、およびコール センター注文の属性をサポートするように拡張されました。 バックオフィスまたは CRT で値を直接編集して設定することができます。 これらすべてはデータベースを変更せずにコンフィギュレーションを介して実行することができます。 (基本的な CRUD 操作は必要ではなく、主要なビジネス ロジックの属性値をカスタマイズすることができます。) 以前は、これを行うには、バックオフィスとチャネル DB に新しいテーブルを作成し、CRT を変更する必要がありました。 現在は、すべての属性の作成をコンフィギュレーションを通じて実行できるようになりました。
新しいテーブルの追加
このシナリオでは、新しいテーブルを作成し、チャネル DB に追加する方法について説明します。 すべての拡張コードは ext スキーマへアクセスすることができます。
SQL Server Management Studio デザイナーを使用するか、SQL スクリプトを使用して、ext スキーマのチャネル データベースに新しいテーブルを作成します。 以下は、SQL スクリプトの例です。
-- Create the extension table to store the custom fields. IF (SELECT OBJECT_ID('[ext].[CONTOSORETAILSTOREHOURSTABLE]')) IS NULL BEGIN CREATE TABLE [ext].[CONTOSORETAILSTOREHOURSTABLE]( [RECID] [bigint] NOT NULL, [DAY] [int] NOT NULL DEFAULT ((0)), [OPENTIME] [int] NOT NULL DEFAULT ((0)), [CLOSINGTIME] [int] NOT NULL DEFAULT ((0)), [RETAILSTORETABLE] [bigint] NOT NULL DEFAULT ((0)), [REPLICATIONCOUNTERFROMORIGIN] [int] IDENTITY(1,1) NOT NULL, [ROWVERSION] [timestamp] NOT NULL, [DATAAREAID] [nvarchar](4) NOT NULL, CONSTRAINT [I_CONTOSORETAILSTOREHOURSTABLE_RECID] PRIMARY KEY CLUSTERED ( [RECID] ASC ) WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] ALTER TABLE [ext].[CONTOSORETAILSTOREHOURSTABLE] WITH CHECK ADD CHECK (([RECID]<>(0))) END GO GRANT SELECT, INSERT, UPDATE, DELETE ON OBJECT::[ext].[CONTOSORETAILSTOREHOURSTABLE] TO [DataSyncUsersRole] GO
メモ
新しい拡張テーブル データが Commerce Data Exchange (CDX) を使用して Retail Headquarters に取り込まれる場合、拡張テーブルは REPLICATIONCOUNTERFROMORIGIN ID 列 ([REPLICATIONCOUNTERFROMORIGIN] [int] IDENTITY(1,1) NOT NULL,), [ROWVERSION] [timestamp] NOT NULL
と [DATAAREAID] [nvarchar](4) NOT NULL
) が含まれる必要があります。 REPLICATIONCOUNTERFROMORIGIN フィールドのみを固有フィールドにすることはできず、テーブル データが会社ごとの場合には必須です。 CDX プル ジョブを実行するためにも必要です。 REPLICATIONCOUNTERFROGIN Retail Headquartersからチャンネル データベースにデータをプッシュする場合は必須ではありません。また、データをチャンネル データベースからRetail Headquartersに引き出す場合にのみ必要になります。
既存のテーブルの拡張
既存のテーブルを拡張する場合は、そのエンティティで対応している場合は属性を使用するか、親テーブルと同じ主キーを持つ拡張テーブル (新しいテーブル) を作成する必要があります。 次のスクリプトはテーブルを拡張します。
CREATE TABLE [ext].[RETAILTRANSACTIONTABLE](
[TRANSACTIONID] [nvarchar](44) NOT NULL, -- FK to [crt].RETAILTRANSACTIONTABLE
[ISB2BSALES] [int] NOT NULL DEFAULT (0),
[EXTERNALID] [nvarchar](20) NOT NULL DEFAULT (''),
CONSTRAINT [EXT_RETAILTRANSACTIONTABLE_PK] PRIMARY KEY CLUSTERED
(
[TRANSACTIONID]
) WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
GRANT INSERT ON [ext].[RETAILTRANSACTIONTABLE] TO [DataSyncUsersRole];
GO
GRANT DELETE ON [ext].[RETAILTRANSACTIONTABLE] TO [DataSyncUsersRole];
GO
GRANT UPDATE ON [ext].[RETAILTRANSACTIONTABLE] TO [DataSyncUsersRole];
GO
GRANT SELECT ON [ext].[RETAILTRANSACTIONTABLE] TO [DataSyncUsersRole];
GO
新しいビュー、ストアド プロシージャ、関数、定義済タイプの追加
すべての新しいストアド プロシージャ、ビューまたは機能は ext スキーマに作成する必要があります。 手順、ビューまたは機能から、データベース コンポーネントをアクセスするまたは呼びだすことはやめてください。
配置のチェック
配置プロセスは、データベースのコンポーネントに変更があるかどうかを判断します。 CRT、AX、または DBO スキーマ オブジェクトを変更しようとした場合、またはどのシナリオの場合でも SQL でそれらに直接アクセスすると、配置は失敗します。
配置のタイムアウト
配置スクリプトを 30 分以上実行すると、SQL Server はタイム アウトになります。 タイムアウトと配置に失敗しないように、実行時間の長いスクリプトを複数の小さなスクリプトに分割し、30 分未満で実行します。
拡張スクリプトおよび展開
チャネル データベース拡張機能は、1 つまたは複数の T-SQL スクリプト ファイルを作成し、配置可能パッケージに含めることで提供されます。 このプロセスについては、Retail SDK ドキュメントで説明します。
拡張スクリプト ファイルは、T-SQL を使用して記述され、Azure SQL データベースと互換性があります。
スクリプト ファイルの末尾は .sql ファイル拡張子にする必要があります。その他のファイルは無視されます。または、パッケージングまたは配置障害を引き起こす可能性があります。 Commerce Scale Unit または Store Commerce アプリ オフラインの一部としてチャネル データベース拡張機能を配置する場合、スクリプトは、それらのコンポーネントに対して使用される SQL Express または SQL Server のバージョンの両方またはいずれかと互換性があることも必要です。
配置とインストール中、拡張子スクリプトは、スクリプト ファイル名に基づいたアルファベット順で実行されます。 各スクリプトは、完了するまで実行され、拡張スクリプトの完了を追跡するため、メタデータ レコードはチャネル データベースの CRT.RETAILUPGRADEHISTORY テーブルに追加されます。
そのメタデータ レコードが存在する場合、その後の配置で同じチャネル データベースに対してスクリプトが再度実行されることはありません。 スクリプトが実行中に失敗し、正常に完了しない場合、そのメタデータは保存されず、以降の配置でスクリプトが再実行されます。
展開やインストールが製品の更新と組み合わされている場合、拡張スクリプトは製品の更新後に実行されます。
正常に動作するチャネル データベース拡張機能を作成するには、次のガイドラインに従う必要があります。
アルファベット順に並べ替えられたときに、安定した順序が確保される名前付け規則を使用します。
拡張スクリプトは、ファイル名に基づくアルファベット順に実行されるので、並べ替えたときに正しい実行順序が使用される名前付け規則を確立する必要があります。
1 つの例は、次のパターンを持つファイルの名前付けです: <ISO 8601 date>_<descriptio>.sql
。ここで <ISO 8601 date>
は ISO 8601 形式の日付で <description>
はスクリプトの目的を識別するための説明のテキストです。 "20180501_CustomerDetails.sql" および "20181102_CustomerDetailsIndex.sql" を例として使用します。前者は、2018 年 5 月 1 日に作成された "顧客の詳細" 機能に関連する拡張スクリプトを表し、後者は、2018 年 11 月 2 日に作成された以前の機能に関連するインデックスに関連付けられた拡張スクリプトを表します。
別の単純な方法は、"0001_CustomerDetails.sql" や "0002_CustomerDetailsIndex.sql" などの差分数値接頭語を使用する方法です。
1 つのスクリプトが正常に実行される別のスクリプトに依存している場合、アルファベット順のファイル名が必要な実行順序と一致していることを確認する方法で命名する必要があります。
公開済の拡張スクリプトを変更しないでください
配置可能パッケージまたはチャネル データベース拡張スクリプトを含むインストーラー拡張機能をリリースした場合、それらのスクリプトを変更しないでください。 拡張スクリプトは、チャネル データベース インスタンスあたり 1 回だけ実行されます。 既にスクリプトを発行しており、それらのスクリプトがチャネル データベースに対して実行済の場合、既に実行されたスクリプトへの変更はデータベースには適用されません。
代わりに、新しいスクリプト ファイル内の変更を提供します。 依存関係の後に実行されるように、上記の名前付け規則を検討してください。
発行済の以前の拡張スクリプトを削除しないでください
展開可能なパッケージまたはインストーラー拡張機能は、データベースの拡張機能の累積的な更新を表す必要があります。 拡張機能パッケージまたはインストーラーの以前のバージョンには依存関係はありません。 ユーザーは、パッケージまたは拡張機能の以前のバージョンに依存しなくても拡張機能パッケージやインストーラーを適用できる必要があります。
拡張スクリプトが配置可能なパッケージまたはインストーラー拡張機能の一部として公開されている場合、パッケージまたはインストーラーの以降の更新から削除しないでください。 障害復旧、アップグレード、スケール アウト シナリオに対応するため、拡張機能パッケージを使用して、チャネル データベースの新しいインスタンスを、最後に配置された拡張機能パッケージと同じバージョンにすることができます。
拡張スクリプトは、非べき等および再入力である必要がある
拡張スクリプトはチャネル データベースあたり 1 回だけ実行されますが、スクリプトはオーサリング エラーまたはタイムアウトやトランザクション デッドロックなどの一時的な SQL エラーが原因で実行されない場合があります。 拡張スクリプトは、それらの障害シナリオに対応するため、非べき等および再入力である必要があります。 拡張スクリプトがエラーが原因で失敗した場合、再実行できます。 スクリプトを再実行しても、データベースに悪影響を及ぼしません。
チャネル データベース データが永続すると仮定しない
チャネル データベースは、Commerce Scale Unit で実行される操作の記憶域サポートを提供するトランザクション データベースです。 長期間保存する必要があるチャネル データベースに格納されるすべてのデータは、Commerce Data Exchange を通じてバックオフィスにアップロードする必要があります。 本社にアップロードされたデータには、Commerce Data Exchange リアルタイム サービスによりアクセスすることができます。
後方互換性のあるチャネルデータベースの拡張機能を作成する
チャネル データベースには下位互換性がある必要があります。 これは、Commerce Scale Unit または POS を更新せずにチャネル データベースのみを更新しても、既存の Commerce Scale Unit または POS 操作が正常に機能するのを妨げてはならないことを意味します。 配置フロー中は、Commerce Scale Unit と Store Commerce アプリのさまざまなコンポーネントが、依存関係なく逆で更新されます。 これは、チャネル データベースが最初に更新されるコンポーネントで、Commerce Scale Unit または POS が次に更新されることを意味します。 Commerce Scale Unit または POS が正常に更新できなかった場合、これらのコンポーネントはロールバックされて、以前の作業状態に戻されます。 このような場合であっても、データの損失を防ぐためにチャネル データベースはロールバックされません。 ご利用の拡張機能に後方互換性がない場合、正常な展開処理が完了するまでは、これら拡張機能が正しく動作しない可能性があります。