Common Data Service (CDS) にはソリューションという便利な機能があります。この記事ではソリューションがどういうもので、何が嬉しいかを説明します。
ソリューションとは
CDS には多くの要素が含まれています。ソリューションの画面から見てみると、現時点で以下のようなコンポーネントが確認でき、実際にはより多くのものが存在します。
例えば複数のエンティティ定義やオプションセットを作成し他の環境にコピーしたい場合、個別に移すのは非常に手間ですし、どのエンティティとどのエンティティが関係あるかなどグルーピングする方法が必要です。
ソリューションを使えば、これらの要素をすべて 1 つにまとめて管理、移行することができます。
ソリューションのタイプ
ソリューションは以下の 3 タイプがあります。
- アンマネージドソリューション : 変更ができるソリューション
- マネージドソリューション : 変更ができないソリューション
- システムソリューション : 既定で存在するソリューションでソリューション一覧にも表示されない
例えば開発環境で追加したものを本番環境に移行する場合、本番環境で勝手に変更されないようにマネージドソリューションを使います。Microsoft もこの方法で Common Data Model (CDM) の Core エンティティなどを CDS に初期登録しています。CDM については Common Data Service で自動的に作られるエンティティについて を参照してください。
レイヤー
CDS では複数のソリューションが共存できるよう、異なるソリューションをレイヤーとして管理します。同じコンポーネントが複数のソリューションにある場合、上位にあるレイヤーのものがユーザーには見えます。
アンマネージドソリューションのレイヤー
アンマネージドソリューションは 1 レイヤーしかありません。また常にレイヤーの最上位に配置されます。ソリューションとしてはアンマネージドソリューションは複数作成が可能ですが、すべて同じレイヤーに配置される点が重要です。
マネージドソリューションのレイヤー
一方マネージドソリューションはインポートした順番でレイヤー化されます。複数のソリューションが同じエンティティやフィールドをカスタマイズしている場合、最後にインポートしたものがユーザーには見えます。
依存関係
あるソリューションのコンポーネントを他のソリューションが参照している場合、依存が発生します。CDS では依存関係が追跡管理され、インポートや削除時に問題にならないように出来ています。
上書きとマージ
レイヤーされた場合の挙動は、コンポーネントによって異なります。
- 上書きされる: 表示名やエンティティのメタデータなどは上位にあるレイヤーのデータが採用される
- マージされる: フォームなどは複数のソリューションの要素がマージされる
マージされるものも完全に一致する項目については、上位レイヤーの値が表示されます。
ソリューション削除時の動作
タイプによって動作が異なります。
アンマネージドソリューションの削除
ソリューションの定義が削除されるだけであり、エンティティなどの要素はシステムに残ります。
マネージドソリューションの削除
エンティティ定義やオプションセットなどすべてのコンポーネントが削除されます。またデータも同時に削除されます。
発行元
ソリューションがどこから発行されたものか分かるように、発行元が紐づけ得られます。発行元ではコンポーネントに付与されるプリフィクスやオプションセットのプリフィクスが設定できるため、同じ名前のカスタムエンティティを他のマネージドソリューションが持っていた場合も、競合が起きません。
データ配下で見ているもの
Power Apps の画面には「データ」セクションがあり、エンティティやオプションセットが確認できます。
これは「既定のソリューション」というアンマネージドソリューションを通してみているものです。
しかし、この画面から追加したコンポーネントは「Common Data Services Default Solution」に含まれます。
以前は明示的にソリューションを作成しない場合、「既定のソリューション」に入る動作であったため、エクスポートした際に不要なコンポーネントもすべて含まれるという課題がありました。ソリューションのことをよく知らないままカスタマイズした場合にも影響を最小限にとどめられるよう、このような動作になっていますが、独自のソリューションを用意して、カスタマイズ/開発することを推奨します。
動作確認
最後にアンマネージドソリューションの動作確認を少しやりましょう。
1. まずソリューションを作成。新規に作成したものはアンマネージドソリューションとなる。
2. 次に「既存のものを追加します」より「エンティティ」を選択。
4. 今回はフォームをカスタマイズしたいため、「コンポーネントを選択します」をクリック。
5.「フォーム」より「取引先企業」フォームを選択して「追加」。
6. 「取引先企業」エンティティがソリューションに追加されたことを確認。
7. 追加された取引先企業を開く。フォームしか追加していないため、フィールドには何も表示されない。
8.「フィールドの追加」より任意のフィールドを追加。プリフィクスとして発行元のものが指定されていることを確認。
9. 「エンティティの保存」をクリック後、フォームより「取引先企業」を開く。
11.「保存」して戻り、「すべてのカスタマイズの発行」をクリック。
12. データより取引先企業を開き、フォームが更新されていることを確認。
この時点で取引先企業のフォームを直接更新した雰囲気はありますが、実際にはアンマネージドソリューションとしてデータベースに保存されており、既存のフォーム情報は上書きされずに残っています。
次にソリューションを削除してみます。
1. ソリューションの一覧より「サンプルソリューション」を選択し、「削除」をクリック。
2. メッセージにも動作が明記されています。確認して「削除」をクリック。
3. ソリューション削除後もフィールドが存在することを確認。
4. 発行元が異なるため、「Common Data Services Default Solution」には含まれない。
5.「既定のソリューション」からは確認出来ることとプリフィクスが変わっていないことを確認。
まとめ
ソリューションは管理面や他環境の移行時に必須の機能となります。別の記事でバージョン管理なども触れたいと思いますが不明点があればコメントしてください。