サンプル: ソリューションの依存関係の検出
このサンプルは、ソリューション コンポーネントを削除する前に依存関係を検出する方法を示します。
このサンプルを実行する方法
- サンプル リポジトリをダウンロードまたは複製して、ローカル コピーを用意します。
- (オプション) Dataverse/App.config ファイルを編集して、接続先の Microsoft Dataverse インスタンスを指定する接続文字列を定義します。
- サンプル ソリューションを Visual Studio で開き、F5 キーを押してサンプルを実行します。 Dataverse/App.config 内に接続文字列を指定した後、サンプルを実行すると、その接続情報が使用されます。
Dataverse/App.config ファイル内に接続文字列を指定しない場合は、サンプルを実行するたびにダイアログが開き、接続先の Dataverse インスタンスについての情報と、使用する資格情報についての情報を入力する必要があります。 このダイアログには以前の接続がキャッシュされているため、以前に使用した接続を選ぶことができます。
このリポジトリにあるサンプルのうち、Dataverse インスタンスに接続する必要があるものには、Dataverse/App.config ファイルを参照するリンクが含まれます。
このサンプルの概要
RetrieveDependentComponentsRequest
、RetrieveDependenciesForDeleteRequest
メッセージはソリューションの依存関係を検出するためのデータを含んでいるシナリオで使用するためのものです。
このサンプルの動作方法
このサンプルの概要で説明されているシナリオをシミュレートするために、サンプルは次のことを行います:
セットアップ
- 組織の現在のバージョンをチェックします。
Publisher
メソッドは、 2 つのソリューションをown
するサンプルの発行元を作成します。Solution
メソッド主要なソリューションを作成します。OptionSetMetadata
は選択値を作成し、それをソリューションに関連付けます。ExportSolutionRequest
は後でインポートできるように、ソリューションをマネージドとしてエクスポートします。DeleteOptionSetRequest
は、以前に作成した選択肢の列を削除するため、マネージド ソリューションの下でインポートすることができます。ImportSolutionRequest
はソリューションをマネージドとして再インポートします。
使用方法
QueryByAttribute
はすべてのソリューションをソリューションにクエリします。RetrieveDependentComponentsRequest
はコンポーネントのすべての依存関係を取得します。 依存関係がない場合は、このコンポーネントを無視できます。 このソリューション コンポーネントに依存関係があり、ソリューション自体がマネージドの場合は、ソリューションを削除できなくなります。
クリーンアップ
セットアップで作成されたソリューションを削除するためのオプションを表示します。 サンプルによって作成されたテーブルとデータを調べる場合、削除はオプションです。 手動でレコードを削除することで同じ結果を得られます。