gpt4 book ai didi

node.js - DynamoDB putItem ConditionExpression 无法匹配 event.identityId

转载 作者:太空宇宙 更新时间:2023-11-03 21:53:27 25 4
gpt4 key购买 nike

我在 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com