首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >DynamoDB -读取项并返回数组大小

DynamoDB -读取项并返回数组大小
EN

Stack Overflow用户
提问于 2016-11-30 07:17:00
回答 2查看 3.9K关注 0票数 2

我在DynamoDB表中有一项。该项目如下:

代码语言:javascript
运行
复制
{
  data: [ 1, 2, 3, 4, 5, 6 ]
  more_data: [ 2, 3, 4, 5, 6, 7 ]
}

使用ProjectionExpression,我可以执行一个GetItem,并且只返回data,或者返回data[0]。但有两件事我搞不懂:

  • 如何返回数组大小?data.SIZE
  • 如何返回数组的子集?data[2-10]

ProjectionExpression文档似乎没有涵盖这一点。有什么线索吗?

EN

回答 2

Stack Overflow用户

发布于 2016-11-30 21:39:37

1) List属性的大小,DynamoDB没有一个函数。可以使用length函数在客户端找到数组元素的大小。

data.Item.records.length给出数组元素records的长度。records是DynamoDB表中的列表。

代码语言:javascript
运行
复制
docClient.get(params, function(err, data) {
    if (err) {
        console.error("Unable to read item. Error JSON:", JSON.stringify(err, null, 2));
    } else {
        console.log("GetItem succeeded:", JSON.stringify(data, null, 2));
        console.log(data.Item[0].records.length);
    }
});

2)在子数组中,语法应该是这样的。DynamoDB不像'records[1-3]'那样支持范围。

代码语言:javascript
运行
复制
ProjectionExpression: 'records[0], records[1]',

3) DynamoDB没有一个函数来获取列表中的最后一项。但是,您可以在客户端获得它。我有records列表。我使用itemValue.records[itemValue.records.length - 1]获得最后一个元素

代码语言:javascript
运行
复制
docClient.query(params, function(err, data) {
    if (err) {
        console.error("Unable to read item. Error JSON:", JSON.stringify(err,
                null, 2));
    } else {
        console.log("GetItem succeeded:", JSON.stringify(data, null, 2));

        data.Items.forEach(function(itemValue) {
            console.log (itemValue.records[itemValue.records.length - 1]);
        });     
    }
});
票数 1
EN

Stack Overflow用户

发布于 2021-06-22 06:50:41

最好把这三个问题写在三页里。

用于(3):

在目前(2021年6月22日)的文档示例中,他们使用size(info.actors)来获得尺寸。您可以使用这个:'size(#list)'来获取列表的大小。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40882426

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档