- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在 AWS Lambda 函数中使用以下 node.js 代码,根据另一个名为 Submissions
的表中的源数据插入或更新名为 StoryEntity
的 DynamoDB 表中的记录> 当 Cognito 同步事件通过在名为“batch”的属性中存储新值来触发此函数时。除了 putItem 调用上的 ConditionExpression 之外,一切似乎都正常工作。如果记录在 StoryEntity
中不存在,一切都很好,但如果它们已经存在,我会在日志输出中报告错误,例如:
2017-11-10T19:08:55.685Z 98e60436-c64a-11e7-9a2a-dfba66e9157a Error inserting: ConditionalCheckFailedException: The conditional request failed
2017-11-10T19:08:55.705Z 98e60436-c64a-11e7-9a2a-dfba66e9157a Error inserting: ConditionalCheckFailedException: The conditional request failed
uid 列中的值类似于 us-east-2:11476ace-a944-4769-89cb-c5ad8e84b8a9
。只要我使用相同的身份登录,它就不会改变。我不明白为什么它不会使用该条件表达式来更新现有记录。 (它是在我引入 ConditionExpression
之前完成的。)
'use strict';
console.log('Loading function');
var doc = require('dynamodb-doc');
var dynamodb = new doc.DynamoDB();
exports.handler = (event, context, callback) => {
var batch = event.datasetRecords.batch.newValue;
var datetime = new Date().getTime();
function doPut(err, data) {
if (err) {
console.log('Error inserting: ' + err);
callback(`Error putting item into DB: ${err}.`);
}}
function doDelete(err, data) {
if (err) {
console.log('Error deleting: ' + err);
callback(`Error deleting item: ${err}.`);
}}
function doQuery(err, data) {
if (err) {
console.log("Error querying: " + err);
callback(`Error querying submission: ${err}`);
} else {
data.Items.forEach(function(item) {
Object.assign(item, {
"uid" : event.identityId,
"date": datetime
});
dynamodb.putItem({"TableName" : "StoryEntity",
"Item" : item,
"ConditionExpression" :
"attribute_not_exists(#u) or #u=:user",
"ExpressionAttributeNames" : {"#u" : "uid"},
"ExpressionAttributeValues" :
{":user":{"S":event.identityId}}
}, doPut);
dynamodb.deleteItem({"TableName" : "Submission",
"Key" : {"Batch" : batch,
"EntityId": item.EntityId}
}, doDelete);
});
}
}
dynamodb.query({ TableName: "Submission",
ProjectionExpression: "EntityId, #t, EntityType, #n, Container, Destination, Target",
KeyConditionExpression: "#b = :batch",
ExpressionAttributeNames: {
"#b" : "Batch",
"#t" : "Text",
"#n" : "Name"
},
ExpressionAttributeValues: {
":batch": batch
}
}, doQuery);
callback(null, event);
};
最佳答案
我仍然不清楚为什么我之前尝试实现此解决方案不成功,但显然问题与 :user
值的格式有关。 。关于此的文档令人沮丧地不一致(我找不到任何与我必须使用的语法相匹配的文档来完成这项工作 - 消除类型说明符键),并且错误消息令人沮丧地模糊,但在修改代码以纠正之后一些异步排序问题,我通过尝试使用 <
获得了更有用的错误消息我的表达式中的运算符而不是 =
。这产生了一条关于如何 <
的消息比较 M
类型的值时不是有效的运算符。显然,在这种情况下,我需要不包含类型指定字符 "S"
在我的值规范中,因为这会导致框架将整个值解释为映射,隐式插入 "M"
key 将值类型指定为映射。我在上面的代码中尝试过,但仍然出现错误,因此必须需要一些其他更改与此相结合才能使其正常工作。以下是最终代码。
'use strict';
console.log('Loading function');
var doc = require('dynamodb-doc');
var dynamodb = new doc.DynamoDB();
exports.handler = (event, context, callback) => {
var batch = event.datasetRecords.batch.newValue;
var datetime = new Date().getTime();
var putList = [];
function putError(err) {
console.log('Error inserting: ' + err);
throw `Error putting item into DB: ${err}.`;
}
function doDelete(err, data) {
if (err) {
console.log('Error deleting: ' + err);
throw `Error deleting item: ${err}.`;
}}
function doQuery(err, data) {
if (err) {
console.log("Error querying: " + err);
throw `Error querying submission: ${err}`;
} else {
data.Items.forEach(function(item) {
Object.assign(item, {
"uid" : event.identityId,
"date": datetime
});
var putRequest = {"TableName" : "StoryEntity",
"Item" : item,
"ConditionExpression" :
"attribute_not_exists(#u) or (#u=:user)",
"ExpressionAttributeNames" : {"#u":"uid"},
"ExpressionAttributeValues" : {":user":event.identityId}
};
var promise = dynamodb.putItem(putRequest).promise();
putList.push({"promise":promise, "entityId":item.EntityId});
});
var promiseList = [];
putList.forEach(function(item){
promiseList.push(item.promise.then(function() {
dynamodb.deleteItem({"TableName" : "Submission",
"Key" : {"Batch" : batch,
"EntityId": item.entityId
}}, doDelete);
}, putError));
});
Promise.all(promiseList).then(function() {
console.log("Success!");
callback(null, event);
}, function(err) {
console.log(err);
callback(err);
});
}
}
dynamodb.query({ TableName: "Submission",
ProjectionExpression: "EntityId, #t, EntityType, #n, Container, Destination, Target",
KeyConditionExpression: "#b = :batch",
ExpressionAttributeNames: {
"#b" : "Batch",
"#t" : "Text",
"#n" : "Name"
},
ExpressionAttributeValues: {
":batch": batch
}
}, doQuery);
};
关于node.js - DynamoDB putItem ConditionExpression 无法匹配 event.identityId,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47229832/
const AWS = require('aws-sdk'); const dynamodb = new AWS.DynamoDB({apiVersion: '2012-08-10'}); expor
我们有一个带有分区键和排序键的 DynamoDB 表。两个键都是数字类型。我正在尝试使用 boto3 DynamoDB 客户端的 PutItem API 插入项目。我收到以下错误; Traceback
我们有一个带有分区键和排序键的 DynamoDB 表。两个键都是数字类型。我正在尝试使用 boto3 DynamoDB 客户端的 PutItem API 插入项目。我收到以下错误; Traceback
我正在使用 AmazonDynamoDBClient putItem 方法在数据库中插入项目。 putItem 的返回类型是 PutItemResult,但我将其设置为 null。 AmazonDyn
我想每次都替换现有记录,所以 putItem 对我来说是正确的操作。但每条记录都有一个创建日期,我不想更新它。因为创建日期始终相同。 是否可以在不首先查询 DynamoDB 的情况下实现此目的?谢谢。
我正在尝试在 DynamoDB put 中执行 ConditionExpression 以检查存储的 bool 值是否为真(在此示例中,用户是否已经过验证不要运行 put),我正在使用 javascr
我正在尝试使用条件在 DynamoDB 上放置一个 interm,但不起作用。 我有一个用户表和一个作为主键的属性 id,属性名称必须是唯一的。 conditions := aws.String("N
我正在尝试从部署在 AWS ElasticBeanStalk 上的 Node 应用程序访问 DynamoDB。我收到一个错误 User is not authorized to perform: dy
我现在刚刚使用 Amazon AWS DynamoDB。在 Future 中,我想将 Items 放在我的表中,但前提是不存在具有相同键的 Item,这样我就不会覆盖现有值。你知道我是怎么做到的吗?我
我在本地的 DynamoDb 中有一个简单的表,并尝试放置这样的项目: var options = {name : "test", creator : "Testcreator
我的 putItem 正在运行。现在我想确保我只更新现有项目的新信息,或者将其添加为新项目: 条件表达式: 如果 partition:sort 不存在则创建新项 如果属性生成则更新 attribut
我正在开发一个 lambda 函数,它将存储有关不同用户的信息。我有一个属性,userID 作为我的主分区键,storedObject 作为我的主排序键。当我使用 PutItem 时,我希望它仅添加
我有一个简单的 JSON 数组,我正在尝试使用变量设置映射键。该数组使用 DynamoDB 的映射功能,第一个名为“hours”的映射包含一个嵌套映射,我希望该映射的键值为 15。但是,因为我希望该键
我在使用无服务器框架的 Lambda 函数时遇到问题,该函数应该将数据放入 DynamoDB。我不确定这个问题,因为当我运行:sls invoke local -f scrape -d 'the-la
我正在将数组中的变量插入 AWS DynamoDB$dbf[$a]['变量1'], $dbf[$a]['变量2'], $dbf[$a]['变量3'] ... 对于一些$a,只设置了'variable1
我有一个 EC2 实例,它打开一个 json 文件,读取每一行并对两个表执行 putItem 操作。 在没有putItem操作的情况下,Golang解析一个67k行的文件大约需要3秒。 通过 putI
我正在尝试设置一个从 AWS Lambda 到 DynamoDB 的小型 api,但我无法确定是否以及如何将对象数组写入键。 我有一个类似的对象 { "teamName": "Team Awe
我有一个用例,在这种情况下,单个请求中的条目列表要更新的情况并不多,而且大多数情况下,只请求更新单个条目。但在未来,这可能会增长,因此我正在考虑使用 BatchPutItem 而不是 PutItem。
我正在努力实现我认为非常标准的东西,但我已经碰壁了。我有一堆数据要存储在 DynamoDB 中 const putDataParams = { TableName: "sens
根据 DynamoDb 文档,为什么有人会使用 updateItem 而不是 putItem? PutItem - 将单个项目写入表中。如果表中存在具有相同主键的项目,则该操作将替换该项目。为了计算
我是一名优秀的程序员,十分优秀!