我正在使用AWS dynamodb中的api“updateItem”来更新项目。主要功能是添加新项目或删除一个现有项目。但是,它们都不适用于以下代码,ADD的错误消息为“”ValidationException:无效的UpdateExpression:运算符或函数的操作数类型不正确;运算符或函数:list_append,操作数类型:S。以下是我的代码:
const data = "newData";
async function updatedb(data) {
return new Promise((resolve, reject) =>{
var params = {
Key: {
"lists": {
S: data
}
},
TableName: "old_lists_DB",
UpdateExpression: "SET #L = list_append(:v,#L) ",
ExpressionAttributeNames: {
"#L": "lists",
},
ExpressionAttributeValues: {
":v": {
S: data
}
}
};
dynamodb.updateItem(params, function(err,data) {
if(err){
reject(err);
}else{
resolve(data);
}
});
});
}
旧的_lists _DB的模式非常简单,只有一个属性:list,值是一组字符串。例如:
{
{"lists" : "a"},
{"lists" : "b"},
{"lists" : "c"},
}
考虑到列表不能是分区键,您有一个不同的分区键,列表只是一个属性。因此,您有一个字符串data
,要将其附加到list类型的列表中。
有了这个,我看到了两件事,
键:这应该包含分区键信息,在本例中,我假设id
为string类型。
list\u append,我们应该传递一个列表本身。因此,expressionattributevalue
我们需要用一个字符串构建一个数组。
这里是修改后的更新代码。
const data = "newData2";
const id = "1";
var params = {
Key: {
id: {
S: id,
},
},
TableName: "old_lists_DB",
UpdateExpression: "SET #L = list_append(:v,#L) ",
ExpressionAttributeNames: {
"#L": "lists",
},
ExpressionAttributeValues: {
":v": {
L: [{ S: data }],
},
},
};
dynamodb.updateItem(params, function (err, result) {
if (err) {
console.log("err", err);
} else {
console.log("result", result);
}
});