是否可以在 DynamoDB 表中更改范围键的值?

2022-09-01 15:33:43

我知道这可能是一个非常愚蠢的问题,但我是DynamoDB的新手。

我怀疑是否有可能在 DynamoDB 中更新范围键的值。

假设我的表是“测试”

{
ID : PK/HK
Date : RK
Name : GSI 
Add : LSI
}

我想修改属性。Date

表中的初始值为:

{
ID = "344"
Date = "5656"
Name = "ABC"
}

在下面运行此代码。我能够更改属性,即GSI。Name

Map<String,AttributeValue> item = new HashMap<String,AttributeValue>();
item.put("ID", new AttributeValue("344"));
item.put("Date", new AttributeValue("5656"));

Map<String,AttributeValueUpdate> item1 = new HashMap<String,AttributeValueUpdate>();

AttributeValueUpdate update = new AttributeValueUpdate().withValue(new AttributeValue("AMIT")).withAction("PUT");
item1.put("Name", update);


UpdateItemRequest updateItemreq = new UpdateItemRequest("Test",item,item1);
UpdateItemResult updateItemres = dynamoDBUSEast.updateItem(updateItemreq);

但是当我改变这条线

item1.put("Name", update);

 item1.put("Date", update);

我收到一些错误

Exception in thread "main" com.amazonaws.AmazonServiceException: One or more parameter values were invalid: Cannot update attribute Date. This attribute is part of the key (Service: AmazonDynamoDBv2; Status Code: 400; Error Code: ValidationException; Request ID: HRRP24Q7C48AMD8ASAI992L6MBVV4KQNSO5AEMVJF66Q9ASUAAJG)
    at com.amazonaws.http.AmazonHttpClient.handleErrorResponse(AmazonHttpClient.java:820)
    at com.amazonaws.http.AmazonHttpClient.executeHelper(AmazonHttpClient.java:439)
    at com.amazonaws.http.AmazonHttpClient.execute(AmazonHttpClient.java:245)
    at com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient.invoke(AmazonDynamoDBClient.java:2908)
    at com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient.updateItem(AmazonDynamoDBClient.java:1256)

那么是否可以更改范围键值?


答案 1

否,就像异常消息所述一样,您 .Cannot update attribute Date. This attribute is part of the key

您还可以在属性更新文档下看到以下内容:

要修改的属性的名称、要对每个属性执行的操作以及每个属性的新值。如果要更新的属性是该表上任何索引的索引键属性,则该属性类型必须与表说明的“属性定义”中定义的索引键类型匹配。您可以使用 UpdateItem 更新任何非键属性。

该文档指出,您可以更新“作为该表上任何索引的索引键属性的属性”的任何属性,这意味着当您更新投影到索引上的属性时,即使它是该索引键的一部分,该索引也将更新以反映原始项。


答案 2

来自 AttributeValueUpdate 的文档

不能使用 UpdateItem 更新任何主键属性。相反,您需要删除该项,然后使用 PutItem 创建具有新属性的新项。


推荐