为了账号安全,请及时绑定邮箱和手机立即绑定

在 GO Lambda 中处理 DynamoDB 项目

在 GO Lambda 中处理 DynamoDB 项目

Go
慕桂英4014372 2022-11-28 10:28:42
我正在执行一个简单的表扫描以从我的 DynamoDB 表中获取所有项目,products. 这是整个 Lambda:package mainimport (    "context"    "fmt"    "github.com/aws/aws-lambda-go/lambda"    "github.com/aws/aws-sdk-go-v2/aws"    "github.com/aws/aws-sdk-go-v2/config"    "github.com/aws/aws-sdk-go-v2/service/dynamodb")type Product struct {    productUUID string    name        string    description string    brand       string    price       string    category    string    dateAdded   string}func handleRequest() (string, error) {    cfg, err := config.LoadDefaultConfig(context.TODO(), func(o *config.LoadOptions) error {        o.Region = "us-east-2"        return nil    })    if err != nil {        panic(err)    }    svc := dynamodb.NewFromConfig(cfg)    out, err := svc.Scan(context.TODO(), &dynamodb.ScanInput{        TableName: aws.String("products"),    })    if err != nil {        panic(err)    }    for _, item := range out.Items {        fmt.Println(item)    }    return "Items", nil // Temporary debugging return (always 200). I'd like to return a json object here}func main() {    lambda.Start(handleRequest)}当我取回数据时,我可以按以下形式打印出每一项:map[brand:0xc0002f38a8 category:0xc0002f3848 dateAdded:0xc0002f3830 name:0xc0002f3800 price:0xc0002f37a0 productUUID:0xc0002f3818]如何将这些项目转换为我在上面定义的结构,然后返回 lambda 预期的 json 响应(基本上是 HTTP 响应代码和 json 形式的项目)?
查看完整描述

1 回答

?
慕码人2483693

TA贡献1860条经验 获得超9个赞

扫描表格会返回项目地图,并且您希望将地图转换为结构,因此为了将地图列表转换为您想要使用aws-sdk-go-v2下的attributevalue.UnmarshalListOfMaps的结构。在以前的版本中,它位于dynamodbattribute中,但他们决定更改 v2 中的包。


products := []Product{}

err = attributevalue.UnmarshalListOfMaps(out.Items, &products)

if err != nil {

    panic(fmt.Sprintf("failed to unmarshal Dynamodb Scan Items, %v", err))

}


productsJson, err := json.Marshal(products)

if err != nil {

    panic(err)

}

我在 Product 结构中看到的一个问题是您需要使用导出的名称,还需要为结构字段定义 json 标签,否则数据将不会解组到结构中。因此,为了将表中的扫描项目返回到 json 响应中,您的代码应如下所示。



package main


import (

    "context"

    "encoding/json"

    "fmt"


    "github.com/aws/aws-lambda-go/events"

    "github.com/aws/aws-lambda-go/lambda"

    "github.com/aws/aws-sdk-go-v2/aws"

    "github.com/aws/aws-sdk-go-v2/config"

    "github.com/aws/aws-sdk-go-v2/feature/dynamodb/attributevalue"

    "github.com/aws/aws-sdk-go-v2/service/dynamodb"

)


type Product struct {

    ProductUUID string `json:"productUUID"`

    Name        string `json:"name"`

    Description string `json:"description"`

    Brand       string `json:"brand"`

    Price       string `json:"price"`

    Category    string `json:"category"`

    DateAdded   string `json:"dateAdded"`

}


func handleRequest() (events.APIGatewayProxyResponse, error) {

    products := []Product{}

    cfg, err := config.LoadDefaultConfig(context.TODO(), func(o *config.LoadOptions) error {

        o.Region = "us-east-2"

        return nil

    })


    if err != nil {

        panic(err)

    }

    svc := dynamodb.NewFromConfig(cfg)


    out, err := svc.Scan(context.TODO(), &dynamodb.ScanInput{

        TableName: aws.String("products"),

    })


    if err != nil {

        panic(err)

    }


    err = attributevalue.UnmarshalListOfMaps(out.Items, &products)

    if err != nil {

        panic(fmt.Sprintf("failed to unmarshal Dynamodb Scan Items, %v", err))

    }


    productsJson, err := json.Marshal(products)

    if err != nil {

        panic(err)

    }


    resp := events.APIGatewayProxyResponse{

        StatusCode:      200,

        IsBase64Encoded: false,

        Body:            string(productsJson),

        Headers: map[string]string{

            "Content-Type": "application/json",

        },

    }


    return resp, nil

}


func main() {

    lambda.Start(handleRequest)

}

PS: 扫描整个 dynamo 表并将其作为响应返回是非常昂贵的,你应该避免它。


查看完整回答
反对 回复 2022-11-28
  • 1 回答
  • 0 关注
  • 110 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信