首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >AWS Lambda:如何向Dynamodb中的NS集添加数字

AWS Lambda:如何向Dynamodb中的NS集添加数字
EN

Stack Overflow用户
提问于 2016-08-14 19:58:36
回答 3查看 5K关注 0票数 7

问题

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

我想要完成的

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

如何将项目添加到表中:

代码语言:javascript
复制
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);

这会导致

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

使用Dynamodb更新项目文档标准

代码语言:javascript
复制
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是一个映射类型,而不是set(?)

代码语言:javascript
复制
"errorMessage": "Invalid UpdateExpression: Incorrect operand type for operator or function; operator: ADD, operand type: MAP"

我也尝试过这些替代方法。

Try 2:

代码语言:javascript
复制
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(相同的错误):

代码语言:javascript
复制
"errorMessage": "Invalid UpdateExpression: Incorrect operand type for operator or function; operator: ADD, operand type: MAP"

Try 3:

代码语言:javascript
复制
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(相同错误):

代码语言:javascript
复制
"errorMessage": "Invalid UpdateExpression: Incorrect operand type for operator or function; operator: ADD, operand type: MAP"

Try 4:

代码语言:javascript
复制
var params = {
    "TableName" : "Hex",
    "Key": {
      "hex": "#FEFEFE"
    },
    "UpdateExpression" : "ADD #oldIds :newIds",
    "ExpressionAttributeNames" : {
      "#oldIds" : "ids"
    },
    "ExpressionAttributeValues": { 
      ":newIds" : [5,6]
   },
};

dynamo.updateItem(params, callback);

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

代码语言:javascript
复制
"errorMessage": "Invalid UpdateExpression: Incorrect operand type for operator or function; operator: ADD, operand type: LIST"

堆栈溢出/我已经尝试过的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,而是使用AWS

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2016-08-15 18:20:21

如何创建集合并将项添加到集合

代码语言:javascript
复制
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表:

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

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

代码语言:javascript
复制
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);

(不要在将来的开发中使用这段代码,我只是为了帮助使用现有DynamoDB文档SDK的人才使用它)

原版为什么会失败

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

代码语言:javascript
复制
"errorMessage": "Invalid UpdateExpression: Incorrect operand type for operator or function; operator: ADD, operand type: MAP"

所以我用错了语法。该解决方案可在(现在已降级的) AWS实验室dynamodb-document-js文档中找到。

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

票数 14
EN

Stack Overflow用户

发布于 2016-08-15 06:30:01

我也一直在纠结这件事。我发现实际上有两个用于DynamoDB的api。

AWS.DynamoDB

AWS.DynamoDBDocumentClient

与您一样,我无法使ADD函数正常工作。我尝试导入和使用DynamoDB api,而不是DynamoDBDocumentClient api。它帮我解决了这个问题。下面是我的代码片段,它使用DynamoDB api,但不使用DynamoDBDocumentClient api。我使用字符串集而不是数字集,但我想这不会有什么区别。

代码语言:javascript
复制
var AWS = require('aws-sdk');
var dynamo = new AWS.DynamoDB();
// var dynamo = new AWS.DynamoDB.DocumentClient();

...

var params = {};
params.TableName = “MyTable”;
params.ExpressionAttributeValues = { ':newIds': { "SS": ["someId"] } };
// :newIds represents a new dynamodb set with 1 element
params.UpdateExpression = "ADD someAttribute :newIds";
dynamoClient.updateItem(params, function(err, data) { ….}
票数 5
EN

Stack Overflow用户

发布于 2019-01-17 08:03:15

这个答案可能对那些使用npm dynamoDB模块的人有帮助。

我们也有同样的问题。当我们使用npm模块进行查询而不是从AWS.DynamoDB模块导出时,给出的AWS.DynamoDBDocumentClint解决方案是可实现的,除非我们可以将npm dynamodb模块转换为AWS.DynamoDB查询。因此,而不是转移/转换查询。

我们试图将dynamoDB npm模块降级到1.1.0版本,结果成功了。以前的版本是1.2.X。

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

https://stackoverflow.com/questions/38946073

复制
相关文章

相似问题

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