登录
首页 >  Golang >  Go问答

DynamoDB 多个过滤条件,给出错误 - buildTree 错误:未设置参数:ConditionBuilder

来源:stackoverflow

时间:2024-04-07 20:45:35 366浏览 收藏

偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《DynamoDB 多个过滤条件,给出错误 - buildTree 错误:未设置参数:ConditionBuilder》,这篇文章主要会讲到等等知识点,不知道大家对其都有多少了解,下面我们就一起来看一吧!当然,非常希望大家能多多评论,给出合理的建议,我们一起学习,一起进步!

问题内容

我正在 go 中使用 lambda 和 dynamodb 构建 rest api。

我需要根据多个过滤器查询数据。

过滤器的数量可能会根据用户在调用 rest api 时提供的查询参数的数量而变化。

根据下面的帖子,我开发了代码来添加多个条件。

适用于 go 的 aws 开发工具包 - dynamodb - 向 filterexpression 添加多个条件

但是当我调用该函数时,我在日志中收到以下错误。-

buildtree 错误:未设置参数:conditionbuilder

不应用过滤表达式,扫描返回所有结果。

这是代码片段。

for queryparam, queryparamvalue := range searchparams {
        fmt.println("queryparam:", queryparam, "=>", "queryparamvalue:", queryparamvalue)
        if queryparam == “param1” {
            param1condition = expression.name(“param1”).equal(expression.value(queryparamvalue))
        }

        if queryparam == “param2” {
            param2condition = expression.name(“param2”).equal(expression.value(queryparamvalue))
        }   
    }


sampleexpr, errsample := expression.newbuilder().
        withcondition(param1condition.or(param2condition)).
        build()
    if errsample != nil {
        fmt.println("error in building sample expr ", errsample)
    } else {
        fmt.println("sampleexpr ", sampleexpr)
    }

    input := &dynamodb.scaninput{
        expressionattributenames:  sampleexpr.names(),
        expressionattributevalues: sampleexpr.values(),
        filterexpression:          sampleexpr.filter(),
        tablename:                 aws.string(deviceinfotable),
    }

但是如果我以不同的方式创建表达式,它就会起作用。

filt := expression.Name("param1").Equal(expression.Value("valu1")).Or(expression.Name("param2").Equal(expression.Value("value2")))

解决方案


conditionbuilder 具有 mode 字段

type conditionbuilder struct {
    operandlist   []operandbuilder
    conditionlist []conditionbuilder
    mode          conditionmode
}

mode 的零值为 unsetcond。当构建条件时,unsetcond 会引发错误。

https://github.com/aws/aws-sdk-go/blob/7798c2e0edc02ba058f7672d32f4ebf6603b5fc6/service/dynamodb/expression/condition.go#L1415

case unsetCond:
        return exprNode{}, newUnsetParameterError("buildTree", "ConditionBuilder")

在您的代码中,如果 queryparam != “param1”queryparam != “param2”,则 param1conditionparam2condition 的 conditionbuilder 值为零,从而在构建时失败。

以上就是《DynamoDB 多个过滤条件,给出错误 - buildTree 错误:未设置参数:ConditionBuilder》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>