DynamoDb Java API - 如果计数器增量不存在则插入

Spy*_*El. 4 amazon-dynamodb

我正在尝试插入不存在的项目并将其计数器设置为 1 或在它存在时将计数器增加 1 但它似乎不起作用...

这是我到目前为止所做的:

UpdateItemSpec updateItemSpec = new UpdateItemSpec()
    .withPrimaryKey("Id", Id)
    .withReturnValues(ReturnValue.ALL_NEW)
    .withUpdateExpression("set #c = if_not_exists(#c = :val, #c + :val)")
    .withNameMap(new NameMap()
        .with("#c", "counter"))
    .withValueMap(new ValueMap()
        .withNumber(":val", 1));
Run Code Online (Sandbox Code Playgroud)

当我将更新表达式更改为set #c = #c + :val它时,它会更新现有项目,但如果它不存在,则不会插入新项目。

set #c = :val 似乎对存在和不存在都有效,但这不是我需要的。

Ale*_*kis 5

您可以通过一次 UpdateItem 调用来创建和更新项目。UpdateExpression 将是ADD #c :val因为 DynamoDB 在对尚不存在的项目的 ADD 操作中假装 Number 的值为零。

  • 在问题之后,上面的代码是:`.withUpdateExpression("ADD #c :val)")` (2认同)