Associer et dissocier des lignes de tables à l’aide de l’API web
Vous pouvez associer des enregistrements individuels dans des lignes de table à d’autres enregistrements à l’aide de Relations qui existent entre les définitions de table. Dans OData, les relations sont exprimées en tant que propriétés de navigation.
Vous pouvez découvrir quelles propriétés de navigation existent dans le document de service $metadata. Voir Propriétés de navigation de l’API web. Pour les tables Dataverse existantes, consultez la Référence EntityType de l’API web. Pour chaque type d’entité, consultez les propriétés de navigation répertoriées à valeur unique et à valeur de collection.
Le tableau suivant décrit les trois types de Relations entre les tables dans Dataverse.
Type | Description | Exemple |
---|---|---|
Un-à-plusieurs | Un enregistrement peut être associé à plusieurs enregistrements. | Un enregistrement de compte peut comporter de nombreux enregistrements de contact dans la contact_customer_accounts propriété de navigation à valeur de collection. |
Plusieurs à un | De nombreux enregistrements peuvent être associés à un enregistrement. Une relation plusieurs-à-un est l’image miroir de la relation un-à-plusieurs. Il n’y a qu’une seule relation. |
Plusieurs enregistrements de contact peuvent être associés à un seul enregistrement de compte à l’aide de la parentcustomerid_account propriété de navigation à valeur unique. |
Plusieurs-à-plusieurs | De nombreux enregistrements peuvent être associés à de nombreux enregistrements. | Chaque rôle de sécurité (rôle) peut inclure des références à la définition d’un utilisateur système. Ces deux tables ont une systemuserroles_association propriété de navigation à valeur de collection. |
Utilisation des propriétés de navigation à valeur unique
Pour les enregistrements existants du côté plusieurs d’une relation un-à-plusieurs ou plusieurs-à-un, vous pouvez associer l’enregistrement en définissant une référence Uri à l’autre enregistrement. La façon la plus simple et la plus courante de le faire consiste à ajouter l’annotation @odata.bind
au nom de la propriété de navigation à valeur unique, puis à définir la valeur comme URI de l’autre enregistrement dans une PATCH
requête.
Association avec une propriété de navigation à valeur unique
Par exemple, pour associer un enregistrement de contact à un compte à l’aide de la parentcustomerid_account
propriété de navigation à valeur unique :
Demande :
PATCH [Organization Uri]/api/data/v9.2/contacts(00aa00aa-bb11-cc22-dd33-44ee44ee44ee) HTTP/1.1
If-Match: *
OData-MaxVersion: 4.0
OData-Version: 4.0
If-None-Match: null
Accept: application/json
{
"parentcustomerid_account@odata.bind": "accounts(ce9eaaef-f718-ed11-b83e-00224837179f)"
}
Réponse :
HTTP/1.1 204 NoContent
OData-Version: 4.0
OData-EntityId: [Organization Uri]/api/data/v9.2/contacts(00aa00aa-bb11-cc22-dd33-44ee44ee44ee)
Comme décrit dans Association des lignes de table pendant la création, de nouveaux enregistrements peuvent également être associés à des enregistrements existants de la même manière.
Dissociation avec une propriété de navigation à valeur unique
Si vous souhaitez dissocier, vous pouvez simplement définir la valeur sur null.
Demande :
PATCH [Organization Uri]/api/data/v9.2/contacts(00aa00aa-bb11-cc22-dd33-44ee44ee44ee) HTTP/1.1
If-Match: *
OData-MaxVersion: 4.0
OData-Version: 4.0
If-None-Match: null
Accept: application/json
{
"parentcustomerid_account@odata.bind": null
}
Réponse :
HTTP/1.1 204 NoContent
OData-Version: 4.0
OData-EntityId: [Organization Uri]/api/data/v9.2/contacts(00aa00aa-bb11-cc22-dd33-44ee44ee44ee)
Quand vous dissociez de cette manière, vous n’avez pas besoin d’inclure l’annotation @odata.bind
. Vous pouvez simplement utiliser le nom de la propriété de navigation à valeur unique :
Demande :
PATCH [Organization Uri]/api/data/v9.2/contacts(00aa00aa-bb11-cc22-dd33-44ee44ee44ee) HTTP/1.1
If-Match: *
OData-MaxVersion: 4.0
OData-Version: 4.0
If-None-Match: null
Accept: application/json
{
"parentcustomerid_account": null
}
Réponse :
HTTP/1.1 204 NoContent
OData-Version: 4.0
OData-EntityId: [Organization Uri]/api/data/v9.2/contacts(00aa00aa-bb11-cc22-dd33-44ee44ee44ee)
More information: Mise à jour de base
Autres méthodes
Il existe d’autres moyens d’obtenir les mêmes résultats que ceux décrits précédemment avec des propriétés de navigation à valeur unique.
Vous pouvez utiliser la requête PUT
suivante pour définir la valeur de la propriété de navigation à valeur unique parentcustomerid_account
:
Demande :
PUT [Organization Uri]/api/data/v9.2/contacts(00aa00aa-bb11-cc22-dd33-44ee44ee44ee)/parentcustomerid_account/$ref HTTP/1.1
OData-MaxVersion: 4.0
OData-Version: 4.0
If-None-Match: null
Accept: application/json
{
"@odata.id": "[Organization URI]/api/data/v9.2/accounts(ce9eaaef-f718-ed11-b83e-00224837179f)"
}
Réponse :
HTTP/1.1 204 NoContent
OData-Version: 4.0
Note
Remarque : vous devez utiliser une URL absolue pendant la définition de la valeur de @odata.id
.
Pour supprimer la référence, vous pouvez également utiliser cette requête DELETE
:
Demande :
DELETE [Organization Uri]/api/data/v9.2/contacts(00aa00aa-bb11-cc22-dd33-44ee44ee44ee)/parentcustomerid_account/$ref HTTP/1.1
OData-MaxVersion: 4.0
OData-Version: 4.0
If-None-Match: null
Accept: application/json
Réponse :
HTTP/1.1 204 NoContent
OData-Version: 4.0
Utilisation des propriétés de navigation à valeur de collection
Avec OData, les deux côtés d’une relation plusieurs-à-plusieurs ont des propriétés de navigation à valeur de collection. Pour les relations un-à-plusieurs et plusieurs-à-un, la table du côté « Un » a une propriété de navigation valeur de collection. Il n’y a aucune différence dans la façon dont vous travaillez avec ces types de relations lorsque vous utilisez des propriétés de navigation à valeur de collection. Cette section décrit comment utiliser des propriétés de navigation à valeur de collection avec n’importe quel type de relation.
Ajouter un enregistrement à une collection
L’exemple suivant montre comment ajouter un enregistrement de contact à la collection de comptescontact_customer_accounts
, qui fait partie d’une relation un-à-plusieurs.
Demande :
POST [Organization Uri]/api/data/v9.2/accounts(ce9eaaef-f718-ed11-b83e-00224837179f)/contact_customer_accounts/$ref HTTP/1.1
OData-MaxVersion: 4.0
OData-Version: 4.0
If-None-Match: null
Accept: application/json
{
"@odata.id": "[Organization URI]/api/data/v9.2/contacts(00aa00aa-bb11-cc22-dd33-44ee44ee44ee)"
}
Réponse :
HTTP/1.1 204 NoContent
OData-Version: 4.0
L’exemple suivant montre comment ajouter un enregistrement de rôle à la collection systemusersystemuserroles_association
, qui est une relation plusieurs-à-plusieurs.
Demande :
POST [Organization Uri]/api/data/v9.2/systemusers(34dcbaf5-f718-ed11-b83e-00224837179f)/systemuserroles_association/$ref HTTP/1.1
OData-MaxVersion: 4.0
OData-Version: 4.0
If-None-Match: null
Accept: application/json
{
"@odata.id": "[Organization URI]/api/data/v9.2/roles(886b280c-6396-4d56-a0a3-2c1b0a50ceb0)"
}
Réponse :
HTTP/1.1 204 NoContent
OData-Version: 4.0
Supprimer un enregistrement d’une collection
L’exemple suivant montre comment supprimer un enregistrement de contact de la collection de comptescontact_customer_accounts
où la valeur contactid
du contact est 00aa00aa-bb11-cc22-dd33-44ee44ee44ee
.
Demande :
DELETE [Organization Uri]/api/data/v9.2/accounts(ce9eaaef-f718-ed11-b83e-00224837179f)/contact_customer_accounts(00aa00aa-bb11-cc22-dd33-44ee44ee44ee)/$ref HTTP/1.1
OData-MaxVersion: 4.0
OData-Version: 4.0
If-None-Match: null
Accept: application/json
Réponse :
HTTP/1.1 204 NoContent
OData-Version: 4.0
La requête suivante fonctionne également :
Demande :
DELETE [Organization Uri]/api/data/v9.2/accounts(ce9eaaef-f718-ed11-b83e-00224837179f)/contact_customer_accounts/$ref?$id=[Organization URI]/api/data/v9.2/contacts(00aa00aa-bb11-cc22-dd33-44ee44ee44ee) HTTP/1.1
OData-MaxVersion: 4.0
OData-Version: 4.0
If-None-Match: null
Accept: application/json
Réponse :
HTTP/1.1 204 NoContent
OData-Version: 4.0
Voir aussi
Exemple d’opérations de base de l’API Web (C#)
Exemple d’opérations de base de l’API Web (Javascript côté client)
Effectuer des opérations à l’aide de l’API Web
Composer des demandes Http et gérer les erreurs
Interroger les données à l’aide de l’API web
Créer une ligne de table à l’aide de l’API web
Récupérer une ligne de table à l’aide de l’API web
Mettre à jour et supprimer des lignes de table à l’aide de l’API web
Utiliser des fonctions API Web
Utiliser des actions API web
Exécuter des opérations par lots à l’aide de l’API Web
Emprunter l’identité d’un autre utilisateur à l’aide de l’API Web
Effectuer les opérations conditionnelles à l’aide de l’API Web