javascript - AWS lambda : How to Add Numbers to a NS Set in Dynamodb

标签 javascript amazon-web-services set amazon-dynamodb aws-lambda

问题

我尝试了几种方法,但一直无法找到如何将数字添加到 NS 集。这一切都在 lambda 函数中运行。

我想要完成的事情

我正在创建一个 dynamodb 表,其中十六进制的不同颜色与一组 ID 对齐。我正在优化表以实现快速读取并避免重复,这就是为什么我想为每个十六进制维护一组 ID。

我如何向表中添加项目:

let doc = require('dynamodb-doc');
let dynamo = new doc.DynamoDB();

var object = {
    'TableName': 'Hex',
    'Item': {
        'hex': '#FEFEFE',
        'ids': {
            'NS': [2,3,4]
        }
    }
}

dynamo.putItem(object, callback);

结果是

results after adding to table

然后我尝试向集合中添加更多 id

使用 Dynamodb Update Item Documentation标准

var params = {
    "TableName" : "Hex",
    "Key": {
      "hex": "#FEFEFE"
    },
    "UpdateExpression" : "ADD #oldIds :newIds",
    "ExpressionAttributeNames" : {
      "#oldIds" : "ids"
    },
    "ExpressionAttributeValues": { 
      ":newIds" : {"NS": ["5", "6"]}
   },
};

dynamo.updateItem(params, callback);

这会返回以下错误,因此 dynamo 认为 :newIds 是一种映射类型而不是集合 (?)

"errorMessage": "Invalid UpdateExpression: Incorrect operand type for operator or function; operator: ADD, operand type: MAP"

我也尝试过这些替代方法

尝试 2:

var setTest = new Set([5, 6]);

var params = {
    "TableName" : "Hex",
    "Key": {
      "hex": "#FEFEFE"
    },
    "UpdateExpression" : "ADD #oldIds :newIds",
    "ExpressionAttributeNames" : {
      "#oldIds" : "ids"
    },
    "ExpressionAttributeValues": { 
      ":newIds" : setTest
   },
};

dynamo.updateItem(params, callback);

错误2(同样的错误):

"errorMessage": "Invalid UpdateExpression: Incorrect operand type for operator or function; operator: ADD, operand type: MAP"

尝试 3:

var params = {
    "TableName" : "Hex",
    "Key": {
      "hex": "#FEFEFE"
    },
    "UpdateExpression" : "ADD #oldIds :newIds",
    "ExpressionAttributeNames" : {
      "#oldIds" : "ids"
    },
    "ExpressionAttributeValues": { 
      ":newIds" : { "NS" : { "L" : [ { "N" : "5" }, { "N" : "6" } ] }}
   },
};

dynamo.updateItem(params, callback);

错误3(同样的错误):

"errorMessage": "Invalid UpdateExpression: Incorrect operand type for operator or function; operator: ADD, operand type: MAP"

尝试 4:

var params = {
    "TableName" : "Hex",
    "Key": {
      "hex": "#FEFEFE"
    },
    "UpdateExpression" : "ADD #oldIds :newIds",
    "ExpressionAttributeNames" : {
      "#oldIds" : "ids"
    },
    "ExpressionAttributeValues": { 
      ":newIds" : [5,6]
   },
};

dynamo.updateItem(params, callback);

错误4(类似的错误,但是dynamo认为我这次添加的是列表)

"errorMessage": "Invalid UpdateExpression: Incorrect operand type for operator or function; operator: ADD, operand type: LIST"

我尝试过的 Stack Overflow/Github 问题

https://stackoverflow.com/a/37585600/4975772 (我添加到一个集合,而不是一个列表)

https://stackoverflow.com/a/37143879/4975772 (我使用的是 javascript,而不是 python,但我基本上需要同样的东西,只是语法不同)

https://github.com/awslabs/dynamodb-document-js-sdk/issues/40#issuecomment-123003444 (我需要做这件事,但我没有使用 dynamodb-document-js-sdk,我使用的是 AWS Lambda

最佳答案

如何创建集合并向集合中添加项目

let AWS = require('aws-sdk');
let docClient = new AWS.DynamoDB.DocumentClient();

...

var params = {
    TableName : 'Hex',
    Key: {'hex': '#FEFEFE'},
    UpdateExpression : 'ADD #oldIds :newIds',
    ExpressionAttributeNames : {
      '#oldIds' : 'ids'
    },
    ExpressionAttributeValues : {
      ':newIds' : docClient.createSet([1,2])
    }
};

docClient.update(params, callback);

生成此 dynamodb 表的结果:

using the

如果该集合不存在,则该代码将为您创建它。您还可以使用不同的集合运行该代码以更新集合的元素。 super 方便。

创建集合并将项目添加到集合(旧 API)

let doc = require('dynamodb-doc');
let dynamo = new doc.DynamoDB();

var params = {
    TableName : 'Hex',
    Key: {'hex': '#555555'},
    UpdateExpression : 'ADD #oldIds :newIds',
    ExpressionAttributeNames : {
      '#oldIds' : 'ids'
    },
    ExpressionAttributeValues : {
      ':newIds' : dynamo.Set([2,3], 'N')
    }
};

dynamo.updateItem(params, callback);

(不要将此代码用于 future 的开发,我包含它只是为了帮助任何使用现有 DynamoDB Document SDK 的人)

为什么原来的失败了

注意当我问这个问题时,结果集看起来像一个文字 json 映射对象(在 dynamodb 屏幕截图中查看),这将解释此错误消息

"errorMessage": "Invalid UpdateExpression: Incorrect operand type for operator or function; operator: ADD, operand type: MAP"

所以我使用了错误的语法。解决方案位于(现已删除)AWS Labs dynamodb-document-js-sdk docs

可在此处查看新文档客户端的完整文档:http://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/DynamoDB/DocumentClient.html

关于javascript - AWS lambda : How to Add Numbers to a NS Set in Dynamodb,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38946073/

相关文章:

javascript - 在 Javascript 中偏移多边形

javascript - 无法调用 jquery 插件方法

amazon-web-services - 无服务器框架不是通过配置在 AWS 上部署 API 网关

Python 根据应用于集合中元素的函数创建结果并集

C++如何循环遍历 map 中的集合?

javascript - 如何从数组中的对象访问值

onload 函数内的 Javascript 变量范围

python - 为什么设置自动解包范围,但列表不?如何使用它?

amazon-web-services - (Kops)Kubernetes服务映射到AWS Route53中的DNS名称吗?

heroku - AWS、Heroku 与其他可扩展平台?