この .NET 6.0 サンプルでは、Dataverse Web API を使用してテーブル、列、およびリレーションシップの定義を作成および変更する演算を実行する方法について説明します。
このサンプルでは、WebAPIService クラス ライブラリ (C#) の共通ヘルパー コードを使用します。
ヒント
この Dataverse 操作のサンプルの実装とコンソール出力は Web API テーブル スキーマ操作サンプルで詳しく説明されています。またコモン C# の構成の使用は Web API のサンプル (C#) で説明されています。
前提条件
以下は、このサンプルの構築および実行に必要となります :
- Microsoft Visual Studio 2022。
- データ演算を実行する権限を使用して Dataverse にアクセスします。
このサンプルを実行する方法
PowerApps-サンプル リポジトリをクローンまたはダウンロードします。
/dataverse/webapi/C#-NETx/MetadataOperations/ フォルダーを見つけます。
Visual Studio 2022 を使用して
MetadataOperations.slnファイルを開きますappsettings.jsonファイルを編集して、以下のプロパティ値を設定します:Property 方法 Urlご使用の環境の Url。 プレースホルダー https://yourorg.api.crm.dynamics.comの値を環境の値に置き換えます。 詳細については、開発者向けリソースを表示する を参照してください。UserPrincipalNameプレースホルダー you@yourorg.onmicrosoft.comの値を環境へのアクセスに使用する UPN の値に置き換えます。Passwordプレースホルダー yourPasswordの値を使用するパスワードに置き換えます。appsettings.jsonファイルを保存しますF5 を押してサンプルを実行します。
Code
このサンプルのコードは次のとおりです: PowerApps-Samples/dataverse/webapi/C#-NETx/MetadataOperations/Program.cs
実際の動作
このサンプルには 11 つのリージョンがあります:
セクション 0: 発行者とソリューションを作成
操作:ソリューション レコードと関連する発行者レコードを作成します。
ヒント
このサンプルで作成されたすべてのソリューション コンポーネントは、エクスポートできるようにソリューションに関連付けられます。 名前付きメッセージのない操作の場合、この関連付けは、値として設定されたソリューションの一意の名前を設定する MSCRM.SolutionUniqueName 要求ヘッダーを使用して作成されます。
ソリューション コンポーネントのすべての名前には、発行者のカスタマイズの接頭辞を使用して接頭辞が付けられます。
セクション 1: テーブルの作成、取得、更新
操作:
-
sample_BankAccount要求をPOSTに送信して、新しい/EntityDefinitionsユーザー所有テーブルを作成します。 -
GET要求を/EntityDefinitions(LogicalName='sample_bankaccount')に送信して、作成されたテーブルを取得します。 -
PUT要求を/EntityDefinitions(LogicalName='sample_bankaccount')に送信して、テーブルを更新します。
セクション 2: 列の作成、取得、更新
操作:
-
sample_boolean要求をsample_BankAccountに送信して、POSTテーブルに新しい/EntityDefinitions(LogicalName='sample_bankaccount')/Attributesブール型の列を作成します。 -
sample_boolean要求をGETに送信して、/EntityDefinitions(LogicalName='sample_bankaccount')/Attributes(LogicalName='sample_boolean')ブール型の列を取得します。 -
sample_boolean要求をPUTに送信して、/EntityDefinitions(LogicalName='sample_bankaccount')/Attributes(LogicalName='sample_boolean')ブール型の列を更新します。 -
sample_booleanを使用して、 ブール列の値のオプション ラベルを更新します。 -
sample_datetimeテーブルの新しいsample_BankAccountdatetime 列を作成して取得します。 -
sample_decimalテーブルの新しいsample_BankAccount小数列を作成して取得します。 -
sample_integerテーブルの新しいsample_BankAccount整数列を作成して取得します。 -
sample_memoテーブルの新しいsample_BankAccountメモ列を作成して取得します。 -
sample_moneyテーブルの新しいsample_BankAccount金額列を作成して取得します。 -
sample_choiceテーブルの新しいsample_BankAccount選択肢列を作成して取得します。 -
sample_choiceを使用して、 列に新しいオプションを追加します。 -
sample_choiceを使用して、 列のオプションの順序を変更します。 -
sample_choiceを使用して、 列のオプションの一つを削除します。 -
sample_multiselectchoicet テーブルの新しいsample_BankAccoun複数選択の選択肢列を作成して取得します。 -
sample_BankAccountを使用して、 テーブルに新しいステータス オプションを作成します。
セクション 3: グローバル OptionSet の作成および使用
操作:
-
sample_colors要求をPOSTに送信して、新しいグローバル選択肢の名前付き/GlobalOptionSetDefinitionsを作成します。 -
sample_colors要求をGETに送信して、/GlobalOptionSetDefinitions(<id value>)グローバル選択肢を取得します。 -
sample_colors要求をsample_BankAccountに送信し、グローバル選択肢に関連付けることによって、sample_colorsグローバル選択肢を使用してPOSTテーブルの新しい/EntityDefinitions(LogicalName='sample_bankaccount')/Attributes選択肢列を作成します。
セクション 4: 顧客リレーションシップの作成
操作:
-
sample_customeridを使用して、sample_BankAccountテーブルに新しい 顧客列を作成します。 -
sample_customerid要求をGETに送信して、/EntityDefinitions(LogicalName='sample_bankaccount')/Attributes(LogicalName='sample_customerid')顧客列を取得します。 -
GET要求を/RelationshipDefinitions(<id>)/Microsoft.Dynamics.CRM.OneToManyRelationshipMetadata.` に送信して、顧客列に作成されたリレーションシップを取得します。
セクション 5: 一対多の関連付けの作成と取得
操作:
-
sample_BankAccountを使用して、 テーブルが 1:N の関連付けで参照できるかどうかを確認します。 -
contactを使用して、 テーブルが 1:N の関連付けで他のテーブルを参照できるかどうかを確認します。 -
sample_BankAccountを使用して、他のどのテーブルが、1:N の関連付けで テーブルを参照できるかを確認します。 -
sample_BankAccount要求をcontactに送信して、POSTと/RelationshipDefinitionsのテーブル間に 1:N の関連付けを作成します。 -
GET要求を/RelationshipDefinitions(<id>)/Microsoft.Dynamics.CRM.OneToManyRelationshipMetadataに送信して、1:N の関連付けを取得します。
セクション 6: 多対一の関連付けの作成と取得
操作:
-
sample_BankAccount要求をaccountに送信して、POSTと/RelationshipDefinitionsのテーブル間に N:1 の関連付けを作成します。 -
GET要求を/RelationshipDefinitions(<id>)/Microsoft.Dynamics.CRM.OneToManyRelationshipMetadataに送信して、N:1 の関連付けを取得します。
セクション 7: 多対多の関連付けの作成と取得
操作:
-
sample_BankAccountを使用して、contactテーブルと テーブルが、N:N の関連付けに参加できるかどうかを確認します。 -
sample_BankAccountを使用して、contactテーブルと テーブルが、N:N の関連付けに参加できるかどうかを確認します。 -
sample_BankAccount要求をcontactに送信して、POSTと/RelationshipDefinitionsのテーブル間に N:N の関連付けを作成します。 -
GET要求を/RelationshipDefinitions(<id>)/Microsoft.Dynamics.CRM.ManyToManyRelationshipMetadataに送信して、N:N の関連付けを取得します。
セクション 8: 管理ソリューションのエクスポート
操作: セクション0: 発行元とソリューションの作成 で作成したソリューションを、ExportSolutionアクションを使用して、このサンプルで作成した項目を含めてエクスポートします。
セクション 9: サンプル レコードを削除
操作: このサンプルで作成された各レコードへの参照は、作成時にリストに追加されました。 このサンプルでは、レコードが $batch 演算を使用して削除されます。
セクション10: 管理ソリューションのインポートと削除
操作:
- ImportSolution アクションを使用して、セクション 8 でエクスポートしたソリューションをインポートします。
- ソリューション テーブルをクエリして、インポートされたソリューションの
solutionidを取得します。 -
solutionidを使用して、インポートされたソリューションを削除します。
クリーンアップ
デフォルトでは、このサンプルで作成されたすべてのレコードが削除されます。 サンプルが完了した後に作成されたレコードを表示する場合は、deleteCreatedRecords 変数を false に変更すると、レコードを削除するかどうかを確認するメッセージが表示されます。
参照
Dataverse Web API を使用する
WebAPIService クラス ライブラリ (C#)
テーブル定義による Web API の利用
Web API のサンプル
Web API 基本操作のサンプル (C#)
Web API クエリ データのサンプル (C#)
Web API 条件付き演算サンプル (C#)
Web API 機能およびアクションのサンプル (C#)
Web API WebApiService の並列演算のサンプル (C#)
TPL データフロー コンポーネントを使用した Web API 並列演算のサンプル (C#)