Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.
Exemple d'expression de condition DynamoDB CLI
Voici quelques AWS Command Line Interface (AWS CLI) exemples d'utilisation d'expressions de condition. Ces exemples sont basés sur la table ProductCatalog
, qui a été présentée dans Référence aux attributs des éléments lors de l'utilisation d'expressions dans DynamoDB. La clé de partition de cette table est Id
; et il n'y a aucune clé de tri. L'opération PutItem
suivante crée un exemple d'élément ProductCatalog
auquel nous ferons référence dans les exemples.
aws dynamodb put-item \ --table-name ProductCatalog \ --item file://item.json
Les arguments de la fonction --item
sont stockés dans le fichier item.json
. Dans un souci de simplicité, seuls quelques attributs sont utilisés.
{ "Id": {"N": "456" }, "ProductCategory": {"S": "Sporting Goods" }, "Price": {"N": "650" } }
Rubriques
Insertion conditionnelle
L'opération PutItem
remplace un élément avec la même clé primaire (si elle existe). Pour éviter cela, utilisez une expression de condition. Elle permet la poursuite de l'écriture uniquement si l'élément en question ne possède pas déjà la même clé primaire.
L'exemple suivant utilise attribute_not_exists()
pour vérifier si la clé primaire existe dans la table avant de tenter l'opération d'écriture.
Note
Si votre clé primaire est composée à la fois d'une clé de partition (pk) et d'une clé de tri (sk), le paramètre vérifiera si l'instruction est attribute_not_exists(pk)
AND attribute_not_exists(sk)
évaluée à vrai ou à faux dans son intégralité avant de tenter l'opération d'écriture.
aws dynamodb put-item \ --table-name ProductCatalog \ --item file://item.json \ --condition-expression "attribute_not_exists(Id)"
Si l'expression de condition prend la valeur false, demandeur renvoie le message d'erreur suivant : The conditional request failed (Échec de la demande conditionnelle)
.
Note
Pour plus d'informations sur attribute_not_exists
et d'autres fonctions, consultez Conditionnez et filtrez les expressions, les opérateurs et les fonctions dans DynamoDB.
Suppressions conditionnelles
Pour effectuer une suppression conditionnelle, utilisez une opération DeleteItem
avec une expression de condition. L'expression de condition doit avoir la valeur true afin que l'opération aboutisse. Dans le cas contraire, l'opération échoue.
Tenez compte de l'élément défini ci-dessus.
Supposons maintenant que vous souhaitiez supprimer l'élément, mais uniquement dans les conditions suivantes :
-
L'attribut
ProductCategory
est soit « Sporting Goods » (Matériels de sport) soit « Gardening Supplies » (Articles de jardinerie). -
Le
Price
est compris entre 500 et 600.
L'exemple suivant tente de supprimer l'élément.
aws dynamodb delete-item \ --table-name ProductCatalog \ --key '{"Id":{"N":"456"}}' \ --condition-expression "(ProductCategory IN (:cat1, :cat2)) and (Price between :lo and :hi)" \ --expression-attribute-values file://values.json
Les arguments de la fonction --expression-attribute-values
sont stockés dans le fichier values.json
.
{ ":cat1": {"S": "Sporting Goods"}, ":cat2": {"S": "Gardening Supplies"}, ":lo": {"N": "500"}, ":hi": {"N": "600"} }
Note
Dans l'expression de condition, le signe :
(deux points) indique une valeur d'attribut d'expression, c'est-à-dire un espace réservé pour une valeur réelle. Pour de plus amples informations, veuillez consulter Utilisation des valeurs d'attributs d'expression dans DynamoDB.
Pour plus d'informations sur IN
, AND
et d'autres mots-clés, consultez Conditionnez et filtrez les expressions, les opérateurs et les fonctions dans DynamoDB.
Dans cet exemple, la comparaison ProductCategory
a la valeur true, mais la comparaison Price
a la valeur false. Il s'ensuit que l'expression de condition prend la valeur false et que l'opération DeleteItem
échoue.
Mises à jour conditionnelles
Pour effectuer une mise à jour conditionnelle, utilisez une opération UpdateItem
avec une expression de condition. L'expression de condition doit avoir la valeur true afin que l'opération aboutisse. Dans le cas contraire, l'opération échoue.
Note
UpdateItem
prend également en charge les expressions de mise à jour, dans lesquelles vous spécifiez les modifications à apporter à un élément. Pour de plus amples informations, veuillez consulter Utilisation d'expressions de mise à jour dans DynamoDB.
Supposons que vous ayez commencé par l'élément défini ci-dessus.
L'exemple suivant effectue une opération UpdateItem
. Elle tente de réduire le Price
d'un produit de 75, mais l'expression de condition empêche la mise à jour si le Price
actuel est inférieur à 500.
aws dynamodb update-item \ --table-name ProductCatalog \ --key '{"Id": {"N": "456"}}' \ --update-expression "SET Price = Price - :discount" \ --condition-expression "Price > :limit" \ --expression-attribute-values file://values.json
Les arguments de la fonction --expression-attribute-values
sont stockés dans le fichier values.json
.
{ ":discount": { "N": "75"}, ":limit": {"N": "500"} }
Si le Price
de départ est 650, l'opération UpdateItem
réduit le Price
à 575. Si vous exécutez à nouveau l'opération UpdateItem
, le Price
est réduit à 500. Si vous l'exécutez une troisième fois, l'expression de condition prend la valeur false et l'opération de mise à jour échoue.
Note
Dans l'expression de condition, le signe :
(deux points) indique une valeur d'attribut d'expression, c'est-à-dire un espace réservé pour une valeur réelle. Pour de plus amples informations, veuillez consulter Utilisation des valeurs d'attributs d'expression dans DynamoDB.
Pour plus d'informations sur « > » et d'autres opérateurs, consultez Conditionnez et filtrez les expressions, les opérateurs et les fonctions dans DynamoDB.
Exemples d'expressions conditionnelles
Pour de plus amples informations sur les fonctions utilisées dans les exemples suivants, veuillez consulter Conditionnez et filtrez les expressions, les opérateurs et les fonctions dans DynamoDB. Pour en savoir plus sur la façon de spécifier différents types d'attributs dans une expression, veuillez consulter Référence aux attributs des éléments lors de l'utilisation d'expressions dans DynamoDB.
Vérification des attributs d'un élément
Vous pouvez vérifier l'existence (ou la non existence) d'un attribut. Si l'expression de condition a la valeur true, l'opération aboutit. Dans le cas contraire, l'opération échoue.
L'exemple suivant utilise attribute_not_exists
pour supprimer un produit uniquement s'il ne possède pas d'attribut Price
.
aws dynamodb delete-item \ --table-name ProductCatalog \ --key '{"Id": {"N": "456"}}' \ --condition-expression "attribute_not_exists(Price)"
DynamoDB fournit également une fonction attribute_exists
. L'exemple suivant supprime un produit uniquement si les commentaires le concernant sont négatifs.
aws dynamodb delete-item \ --table-name ProductCatalog \ --key '{"Id": {"N": "456"}}' \ --condition-expression "attribute_exists(ProductReviews.OneStar)"
Vérification du type d'attribut
Vous pouvez vérifier le type de données d'une valeur d'attribut à l'aide de la fonction attribute_type
. Si l'expression de condition a la valeur true, l'opération aboutit. Dans le cas contraire, l'opération échoue.
L'exemple suivant utilise attribute_type
pour supprimer un produit uniquement s'il possède un attribut Color
de type String Set.
aws dynamodb delete-item \ --table-name ProductCatalog \ --key '{"Id": {"N": "456"}}' \ --condition-expression "attribute_type(Color, :v_sub)" \ --expression-attribute-values file://expression-attribute-values.json
Les arguments pour --expression-attribute-values
sont stockés dans le fichier expression-attribute-values .json.
{ ":v_sub":{"S":"SS"} }
Vérification de la valeur de début de la chaîne
Vous pouvez vérifier si une valeur d'attribut String commence par une sous-chaîne spécifique à l'aide de la fonction begins_with
. Si l'expression de condition a la valeur true, l'opération aboutit. Dans le cas contraire, l'opération échoue.
L'exemple suivant utilise begins_with
pour supprimer un produit uniquement si l'élément FrontView
de la carte Pictures
commence par une valeur spécifique.
aws dynamodb delete-item \ --table-name ProductCatalog \ --key '{"Id": {"N": "456"}}' \ --condition-expression "begins_with(Pictures.FrontView, :v_sub)" \ --expression-attribute-values file://expression-attribute-values.json
Les arguments pour --expression-attribute-values
sont stockés dans le fichier expression-attribute-values .json.
{ ":v_sub":{"S":"http://"} }
Recherche d'un élément dans un ensemble
Vous pouvez rechercher un élément dans un ensemble ou rechercher une sous-chaîne dans une chaîne à l'aide de la fonction contains
. Si l'expression de condition a la valeur true, l'opération aboutit. Dans le cas contraire, l'opération échoue.
L'exemple suivant utilise contains
pour supprimer un produit uniquement si l'attribut de type String Set Color
comporte un élément avec une valeur spécifique.
aws dynamodb delete-item \ --table-name ProductCatalog \ --key '{"Id": {"N": "456"}}' \ --condition-expression "contains(Color, :v_sub)" \ --expression-attribute-values file://expression-attribute-values.json
Les arguments pour --expression-attribute-values
sont stockés dans le fichier expression-attribute-values .json.
{ ":v_sub":{"S":"Red"} }
Vérification de la taille d'une valeur d'attribut
Vous pouvez vérifier la taille d'une valeur d'attribut à l'aide de la fonction size
. Si l'expression de condition a la valeur true, l'opération aboutit. Dans le cas contraire, l'opération échoue.
L'exemple suivant utilise size
pour supprimer un produit uniquement si la taille du binary attribute VideoClip
est supérieure à 64000
octets.
aws dynamodb delete-item \ --table-name ProductCatalog \ --key '{"Id": {"N": "456"}}' \ --condition-expression "size(VideoClip) > :v_sub" \ --expression-attribute-values file://expression-attribute-values.json
Les arguments pour --expression-attribute-values
sont stockés dans le fichier expression-attribute-values .json.
{ ":v_sub":{"N":"64000"} }