提问者:小点点

如何将updateExpression与节点的AttributesUpdates一起使用。js AWS发电机


我正在使用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"},
}

共1个答案

匿名用户

考虑到列表不能是分区键,您有一个不同的分区键,列表只是一个属性。因此,您有一个字符串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);
  }
});