登录
首页 >  Golang >  Go问答

多属性的 UpdateItem

来源:stackoverflow

时间:2024-02-19 10:27:28 493浏览 收藏

最近发现不少小伙伴都对Golang很感兴趣,所以今天继续给大家介绍Golang相关的知识,本文《多属性的 UpdateItem》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

问题内容

我正在尝试更新一个具有许多属性(超过 100 个)的项目。我可以看到有两种方法可以更新此项目。

putitem:putitem 可以更新项目,根据我的理解,我需要为每个请求发送所有 100 个属性,因为我使用结构来封送和解封请求数据。如果我跳过任何字段,默认值将插入到表中。

updateiteminput:我们可以使用 updateiteminput 更新表格,如下 -

svc := dynamodb.New(session.New())
    input := &dynamodb.UpdateItemInput{
    ExpressionAttributeNames: map[string]*string{
        "#AT": aws.String("AlbumTitle"),
        "#Y":  aws.String("Year"),
    },
    ExpressionAttributeValues: map[string]*dynamodb.AttributeValue{
        ":t": {
            S: aws.String("Louder Than Ever"),
        },
        ":y": {
            N: aws.String("2015"),
        },
    },
    Key: map[string]*dynamodb.AttributeValue{
        "Artist": {
            S: aws.String("Acme Band"),
        },
        "SongTitle": {
            S: aws.String("Happy Day"),
        },
    },
    ReturnValues:     aws.String("ALL_NEW"),
    TableName:        aws.String("Music"),
    UpdateExpression: aws.String("SET #Y = :y, #AT = :t"),
}

result, err := svc.UpdateItem(input)

这里我们需要为很多属性编写expressionattributenames,如果要更新的属性是动态的我应该如何处理。

我不确定哪种是处理更新的有效方法。请建议哪种方法更好,或者有其他方法来处理这种情况。


解决方案


您是对的,PutItem 替换具有相同键的任何现有项目,因此如果您只想合并一堆新属性值到现有项目中,您需要使用UpdateItem

正如您所说,一种选择确实是使用 UpdateExpression 语法。您需要创建一个字符串,例如 SET #a1 = :a1, SET #a2 = :a2, ... 以及所有设置这些 a1 等,但这并不是一个困难的编程练习。

另一个选项是使用旧的 AttributeUpdates 语法和一堆 PUT 操作来代替 UpdateExpression。这可能稍微容易一些(您只需构建一个 JSON 列表,而不是一个表达式加两个列表),但这两者都需要一些简单的编程。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《多属性的 UpdateItem》文章吧,也可关注golang学习网公众号了解相关技术文章。

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