2016-09-03 111 views
0

我想扫描AWS DynamoDB表,然后只拉取某个值。这里是我的代码:如何检索嵌套的映射值

package main 

import (
    "fmt" 

    "github.com/aws/aws-sdk-go/aws" 
    "github.com/aws/aws-sdk-go/aws/session" 
    "github.com/aws/aws-sdk-go/service/dynamodb" 
) 

func main() { 
    svc := dynamodb.New(session.New(), &aws.Config{Region: aws.String("us-west-2")}) 

    params := &dynamodb.ScanInput{ 
     TableName: aws.String("my_Dynamo_table_name"), 
     Limit: aws.Int64(2), 
    } 

    resp, err := svc.Scan(params) 
    if err != nil { 
     fmt.Println(err.Error()) 
     return 
    } 

    fmt.Println(resp) 
} 

和输出是:

{ 
    Count: 2, 
    Items: [{ 
     update_time: { 
     N: "1466495096" 
     }, 
     create_time: { 
     N: "1465655549" 
     } 
    },{ 
     update_time: { 
     N: "1466503947" 
     }, 
     create_time: { 
     N: "1466503947" 
     } 
    }], 
    LastEvaluatedKey: { 
    Prim_key: { 
     S: "1234567890" 
    } 
    }, 
    ScannedCount: 2 
} 

现在,我想检索上述输出的所有元素update_time值。这里是我的尝试:

for _, value := range resp.Items { 
    fmt.Println(value["create_time"]["N"]) 
} 

for _, value := range resp.Items { 
    fmt.Println(value.create_time.N) 
} 

for _, value := range resp.Items { 
    fmt.Println(*value.create_time.N) 
} 

所有上述尝试错误出与/var/tmp/dynamo.go:37: invalid operation:错误。 我来自perl/python背景,最近开始学习golang。

如何在这种情况下检索嵌套的地图/数组值。此外,任何阅读参考将有很大的帮助。我的谷歌搜索没有透露任何相关信息。

回答

1

上面的值resp*ScanOutput的类型,它有Items类型为[]map[string]*AttributeValue

要访问update_time,你可以尝试:

updateTimes := make([]string, 0) 

// Items is a slice of map of type map[string]*AttributeValue 
for _, m := range resp.Items { 
    // m is of type map[string]*AttributeValue 
    timeStrPtr := *m["update_time"].N 
    updateTimes = append(updateTimes, *timeStrPtr) 
} 

updateTimes现在应该包含所有"update_time"值作为字符串。

更多详细信息here

+1

我编辑你的'for'环一点点。感谢您的意见。我在python/ruby​​中运行了精确的类似代码,'resp'是一个标准的Python字典/红宝石哈希。所以很容易检索这些值。我甚至还想着,回应是一张地图,因此我无法得到它的工作。并感谢文档链接。 – slayedbylucifer

0

您应该使用dynamodbattribute包。它更便宜,更安全,更具可读性。

按照你的例子:

type Row struct { 
    CreateTime int `dynamodbav:"create_time"` 
    UpdateTime int `dynamodbav:"update_time"` 
} 

// ... 
rows := make([]*Row, len(resp.Items)) 
if err := dynamodbattribute.Unmarshal(resp.Items, &rows); err != nil { 
    // handle the error  
} 

// access the data 
for _, row := range rows { 
    fmt.Println(row.CreateTime, row.UpdateTime)  
}