dongyi1429 2019-04-20 20:40
浏览 93
已采纳

在Dynamo DB中查询索引

I need an example in Go on how to do a query on an index in dynamo db. For JavaScript I found this one: https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/SQLtoNoSQL.Indexes.QueryAndScan.html

I could not find one for Go. I tried this:

    // Here "user_id" is the key, and
    // "user_id_index" is the secondary index

    keyCondition := expression.Key("user_id").Equal(expression.Value(userId))
    expr, errExpression := expression.NewBuilder().WithKeyCondition(keyCondition).WithProjection(proj).Build()

    if errExpression != nil {
        log.Printf("error: creating dynamo expression ", errExpression)

        return listResponse, errExpression
    }
    params := &dynamodb.QueryInput{
        ExpressionAttributeValues: expr.Values(),
        ProjectionExpression:      expr.Projection(),
        TableName:                 aws.String(tableName),
        IndexName:                 aws.String("user_id_index"),
        KeyConditionExpression:    expr.KeyCondition(),

    }
    result, errResults := svc.Query(params)

I get the following error:

error: scanning dynamo table %!(EXTRA *awserr.requestError=ValidationException:
 Invalid KeyConditionExpression: An expression attribute name used in the document path is not defined;
 attribute name: #0

Any link to a good tutorial would be appreciated, or code example as an answer too.

  • 写回答

1条回答 默认 最新

  • dov6891 2019-04-20 21:46
    关注

    I think you're missing expression attribute names. Try adding this to your query input:

    ExpressionAttributeNames:  expr.Names(),
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 哪个tomcat中startup一直一闪而过 找不出问题
  • ¥15 这个怎么改成直流激励源给加热电阻提供5a电流呀
  • ¥50 求解vmware的网络模式问题 别拿AI回答
  • ¥24 EFS加密后,在同一台电脑解密出错,证书界面找不到对应指纹的证书,未备份证书,求在原电脑解密的方法,可行即采纳
  • ¥15 springboot 3.0 实现Security 6.x版本集成
  • ¥15 PHP-8.1 镜像无法用dockerfile里的CMD命令启动 只能进入容器启动,如何解决?(操作系统-ubuntu)
  • ¥30 请帮我解决一下下面六个代码
  • ¥15 关于资源监视工具的e-care有知道的嘛
  • ¥35 MIMO天线稀疏阵列排布问题
  • ¥60 用visual studio编写程序,利用间接平差求解水准网