我正在尝试插入不存在的项目并将其计数器设置为 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 似乎对存在和不存在都有效,但这不是我需要的。
您可以通过一次 UpdateItem 调用来创建和更新项目。UpdateExpression 将是ADD #c :val因为 DynamoDB 在对尚不存在的项目的 ADD 操作中假装 Number 的值为零。
| 归档时间: |
|
| 查看次数: |
1379 次 |
| 最近记录: |