Maison >développement back-end >Golang >Comment créer des expressions de filtre complexes avec plusieurs conditions dans AWS SDK for Go ?
Comment ajouter plusieurs conditions à FilterExpression à l'aide du kit AWS SDK for Go
Le kit AWS SDK for Go fournit un générateur d'expression pour simplifier la tâche de création d'expressions de filtre complexes pour les opérations d'analyse DynamoDB. Par défaut, tenter d'ajouter plusieurs conditions à l'aide du générateur d'expression écrase la condition précédente, vous laissant avec un seul filtre.
Approche utilisant la structure ConditionBuilder
Pour surmonter cette limitation , la structure ConditionBuilder propose des méthodes pour combiner plusieurs conditions à l'aide d'opérateurs logiques. Par exemple, le code suivant montre comment ajouter plusieurs conditions à l'aide de la méthode And() :
<code class="go">cond1 := expression.Name("foo").Equal(expression.Value(5)) cond2 := expression.Name("bar").Equal(expression.Value(6)) expr, err := expression.NewBuilder(). WithCondition(cond1.And(cond2)). Build()</code>
Vous pouvez également utiliser les méthodes Or() et Not() pour combiner des conditions avec la logique OR et NOT. , respectivement.
Approche alternative : création manuelle d'expressions
Si vous préférez construire l'expression de filtre manuellement, vous pouvez utiliser la fonction expression.New() pour créer un Objet d'expression, puis ajoutez des conditions à l'aide des méthodes And() ou Or(). Par exemple :
<code class="go">expr := expression.New() expr.AndWith(expression.Name("foo").Equal(expression.Value(5))) expr.OrWith(expression.Name("bar").Equal(expression.Value(6)))</code>
Référence de la documentation
Pour plus d'informations sur l'utilisation du générateur d'expression, reportez-vous à la documentation AWS SDK for Go sur [ExpressionBuilder](https : //pkg.go.dev/github.com/aws/aws-sdk-go/aws/dynamodb/expression#ConditionBuilder).
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!