Rumah > pembangunan bahagian belakang > Golang > Cara mengemas kini hanya satu medan dalam DynamoDB menggunakan AWS Go SDK

Cara mengemas kini hanya satu medan dalam DynamoDB menggunakan AWS Go SDK

WBOY
Lepaskan: 2024-02-05 23:51:12
ke hadapan
554 orang telah melayarinya

如何使用 AWS Go SDK 仅更新 DynamoDB 中的单个字段

Kandungan soalan

Semoga seseorang dapat memberi sedikit pencerahan tentang isu yang saya hadapi ini.

Saya ada meja ini dalam dinamo, jom panggil people ,在这个表中,我有 id 的属性作为我们的分区键、namelastnamestatus . Saya mahu dapat mengemas kini hanya satu harta atau menyimpan semua sifat id. Sekarang, ini adalah cara saya melakukannya. Saya mencipta struktur berikut:

type personupdate struct {
    firstname     string `json:"firstname,omitempty"`
    lastname      string `json:"lastname,omitempty"`
    status        string `json:"status,omitempty"`
}
Salin selepas log masuk

Permintaan daripada pelayan hanya mengemas kini nama keluarga orang itu, jadi badan permintaan kami akan kelihatan seperti ini:

{
    "lastname": "bob"
}
Salin selepas log masuk

Selepas mengikat permintaan pada struktur, objek yang akan dihantar ke dinamo akan kelihatan seperti ini:

{
    "firstname": "",
    "lastname": "bob",
    "status": "",
}
Salin selepas log masuk

Sekarang, seperti yang anda lihat, apabila tiba masanya untuk menulis kepada dynamo, hanya satu sifat perlu dikemas kini dan selebihnya sifat kosong/kosong harus diabaikan.

Kod yang ditulis untuk melakukan ini boleh dipekatkan kepada yang berikut:

// marshal our object
    _, err := dynamodbattribute.marshalmap(person)
    if err != nil{
        fmt.println("some error marshaling")
    }
    // create our update input
    input := &dynamodb.updateiteminput{
        key: map[string]*dynamodb.attributevalue{
            "id":{
                s: aws.string("1234"),
            },
        },
        tablename: aws.string("people"),
        expressionattributevalues: map[string]*dynamodb.attributevalue{
            ":fn": {
                s: aws.string(person.firstname),
            },
            ":ln":{
                s: aws.string(person.lastname),
            },
            ":st":{
                s: aws.string(person.status),
            },
        },
        updateexpression: aws.string("set firstname = :fn, lastname = :ln, status = :st"),
        returnvalues: aws.string("updated_new"),
    }
    // send update request to dynamo
    _, err := service.updateitem(input)
Salin selepas log masuk

Kini, tiada masalah dengan mengemas kini, masalahnya ialah bendera firstnamestatus 的 null 值也被传递。我尝试过阅读他们的文档,但还是有点困惑。我知道java sdk允许您传递一个名为update_skip_null_attributes, yang membolehkan anda melangkau nilai nol tersebut dan mengemas kini hanya nilai yang mempunyai data. Saya tidak tahu apa yang setara dengannya, sebarang bantuan/tunjuk ajar akan menjadi bagus.

Kemas kini:

Cuba gunakan model berikut:

type usermodel struct {
    firstname string `json:"firstname,omitempty" dynamodbav:"firstname,omitempty"`
    lastname  string `json:"lastname,omitempty" dynamodbav:"lastname,omitempty"`
}
Salin selepas log masuk

Ikuti nasihat yang diberikan oleh @jarmod dan @fedonev. Secara logik dan menggunakan dokumentasi adalah mungkin untuk memahami mengapa ini harus berfungsi, malangnya ia tidak

Memutuskan untuk menukar sdk daripada v1 kepada v2 untuk melihat sama ada mengemas kini ia akan membantu, walaupun saya terperangkap dalam keadaan yang sama sekali lagi. Inilah rupa fungsi kemas kini saya.

update :=expression.Set(expression.Name("firstName"),expression.Value(user.FirstName))
    update.Set(expression.Name("lastName"), expression.Value(user.LastName))

    expr, err := expression.NewBuilder().WithUpdate(update).Build()

    if err != nil {
        "log error here..."
    }

    _, err = svc.UpdateItem(context.TODO(), &dynamodb.UpdateItemInput{
        TableName:                 aws.String("people"),
        Key:                       map[string]types.AttributeValue{"id": id},
        ExpressionAttributeNames:  expr.Names(),
        ExpressionAttributeValues: expr.Values(),
        UpdateExpression:          expr.Update(),
        ReturnValues:              types.ReturnValueUpdatedNew,
    })

    if err != nil {
        "log error here..."

    }
Salin selepas log masuk

Saya akhirnya menyelesaikan masalah saya dengan menulis pertanyaan dan mencipta fungsi yang cukup banyak menanyakan muatan json dengan id yang ingin kami kemas kini dan mengemas kini berdasarkan perbezaan perkara yang perlu kami tanyakan, sebarang medan kosong akan ditanya Penggantian hasil. Setakat ini ia menyelesaikan masalah saya, tetapi saya masih tertanya-tanya bagaimana untuk mengemas kininya dengan fungsi yang dimaksudkan.


Jawapan betul


Seperti komen @jarmod, medan bernilai sifar dilangkau apabila menggunakan dynamodbav:",omitempty" tag pada marshalling structures:

type personupdate struct {
    firstname     string `json:"firstname,omitempty" dynamodbav:",omitempty"`
    lastname      string `json:"lastname,omitempty" dynamodbav:",omitempty"`
    status        string `json:"status,omitempty" dynamodbav:",omitempty"`
}
Salin selepas log masuk

[EDIT: Penggunaan tambahan] marshalmap Medan nilai sifar kini akan diabaikan, menghormati label. Lelaran di atas peta untuk membina ungkapan kemas kini:

av, _ := attributevalue.MarshalMap(person)

update := expression.UpdateBuilder{}

for k, v := range av {
        update = update.Set(expression.Name(k), expression.Value(v))
}
Salin selepas log masuk

Bina ekspresi dan hantar outputnya kepada updateitem seperti yang ditunjukkan dalam op.

Atas ialah kandungan terperinci Cara mengemas kini hanya satu medan dalam DynamoDB menggunakan AWS Go SDK. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:stackoverflow.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan