提问者:小点点

尝试在发电机数据库中运行更新项目时遇到问题


我能够从发电机数据库获取记录并成功查看响应。我需要修改“items”数组中获取的“ACCOUNTNAME”属性并更新 json,并在 dynamo 数据库中更新。现在,当我尝试更新获取的记录时,我最终会遇到无效的属性值类型异常。

我试图使用带有字符串数组的键更新它,该数组提供了代码片段,还尝试使用单个字符串在 for 循环中更新,但都失败了,异常相同

  "statusCode": 400,
  "body": {
    "message": "Invalid attribute value type",
    "error": {
      "errorMessage": "ValidationException"
    }
  }

我尝试通过设置键来创建参数并更新 for 循环中的调用,如下所示,

      Key: {
       "UUID": {
            "S": usersOfAccountFromDB.body.Items[key].UUID
        }
        ,
       "TYPE": {
            "S": user
        }  
      }

但也失败了,有同样的例外。

从发电机数据库获取 Json

[
  {
    "DEFINITION": "914ba44a-8c26-4b60-af0f-96b6aa37efe6",
    "UUID": "830a49cb-4ed3-41ae-b111-56714a71ab98",
    "TYPE": "USER",
    "RELATION": "01efd131-6a5d-4068-889e-9dba44262da5",
    "ACCOUNTNAME": "Wolff LLC"
  },
  {
    "DEFINITION": "1f60fded-323d-40e1-a7f8-e2d053b0bed0",
    "UUID": "47db3bbe-53ac-4e58-a378-f42331141997",
    "TYPE": "USER",
    "RELATION": "01efd131-6a5d-4068-889e-9dba44262da5",
    "ACCOUNTNAME": "Wolff LLC"
  },
  {
    "DEFINITION": "05ddccba-2b6d-46bd-9db4-7b897ebe16ca",
    "UUID": "e7290457-db77-48fc-bd1a-7056bfce8fab",
    "TYPE": "USER",
    "RELATION": "01efd131-6a5d-4068-889e-9dba44262da5",
    "ACCOUNTNAME": "Wolff LLC"
  },
.
.
.
.]

现在我尝试迭代 Json 并设置 UUID,这是字符串数组的关键,如下所示,

    var userUUIDArray : string[] = [];
    for (let key in usersOfAccountFromDB.body.Items) {
      userUUIDArray.push(usersOfAccountFromDB.body.Items[key].UUID);
    }

    for (var uuid of userUUIDArray) {
    console.log("UUID : " +uuid);     // prints all the uuid
    }

    // Creating a parameter for the update dynamo db
    var params = {
    TableName: <tableName>,
    Key: {
      "UUID": {
            "SS": userUUIDArray
        }
        ,
      "TYPE": {
            "S": user
        }  
    },               
    UpdateExpression: 'SET #ACCOUNTNAME = :val1',
    ExpressionAttributeNames: {
        '#ACCOUNTNAME': 'ACCOUNTNAME'       //COLUMN NAME   
    },
    ExpressionAttributeValues: {
      ':val1': newAccountName  
    },
    ReturnValues: 'UPDATED_NEW',
    };

    //call the update of dynamodb
    const result = await this.getDocClient().update(param).promise();

我得到如下错误,

    "body": {
    "message": "Invalid attribute value type",
    "error": {
      "errorMessage": "ValidationException"
      }
    }

所有方法都失败了,但上述异常相同


共2个答案

匿名用户

代码当前使用的更新操作仅允许更新单个项。

IIUC,您希望通过一个 API 调用更新多个项目。为此,您需要使用 batchWrite 操作。请记住,每次调用更新的项目不能超过 25 个。

由于在 UUID 字段中使用了“SS”,您的代码失败。此字段的类型为字符串,因此必须使用“S”。但请注意,由于您使用的是文档客户端 API,因此不需要使用此表示法传递值。有关更多详细信息,请参阅此答案。

匿名用户

我现在通过使用循环逐个运行更新语句解决了这个问题

for (let key in usersOfAccountFromDB.body.Items) {

  var updateParam = {
    TableName: process.env.AWS_DYNAMO_TABLE,
    Key: {
      UUID: usersOfAccountFromDB.body.Items[key].UUID,      
      TYPE: user 
    },     
    UpdateExpression: "SET #ACCOUNTNAME = :val1",
    ExpressionAttributeNames: {
        '#ACCOUNTNAME': 'ACCOUNTNAME'   
    },
    ExpressionAttributeValues: {
        ":val1": newAccountName
    },
    ReturnValues: "UPDATED_NEW",
  };

  const result = await this.getDocClient().update(updateParam).promise();                   
}