加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – DynamoDB API:如何构建“添加JSON属性(如果不存在”)更

发布时间:2020-12-15 00:20:44 所属栏目:Java 来源:网络整理
导读:我试图使用新的 Amazon DynamoDB JSON API在名为“document”的JSON属性中添加/覆盖键值对.理想情况下,我想简单地构造我的写调用来发送KV对以添加到属性,并且如果给定的主键不存在,那么Dynamo会创建该属性.但是,如果我尝试这个只是一个简单的UpdateItemSpec
我试图使用新的 Amazon DynamoDB JSON API在名为“document”的JSON属性中添加/覆盖键值对.理想情况下,我想简单地构造我的写调用来发送KV对以添加到属性,并且如果给定的主键不存在,那么Dynamo会创建该属性.但是,如果我尝试这个只是一个简单的UpdateItemSpec:
PrimaryKey primaryKey = new PrimaryKey("key_str","mapKey");
ValueMap valuesMap = new ValueMap().withLong(":a",1234L).withLong(":b",1234L);
UpdateItemSpec updateSpec = new UpdateItemSpec().withPrimaryKey(primaryKey).withUpdateExpression("SET document.value1 = :a,document.value2 = :b");
updateSpec.withValueMap(valuesMap);
table.updateItem(updateSpec);

我得到com.amazonaws.AmazonServiceException:更新表达式中提供的文档路径对于更新是无效的,意味着DynamoDB找不到要应用更新的名为“document”的给定属性.

我通过以下一系列呼叫设法近似该功能:

try {
    // 1. Attempt UpdateItemSpec as if attribute already exists
} catch (AmazonServiceException e) {
    // 2. Confirm the exception indicated the attribute was not present,otherwise rethrow it
    // 3. Use a put-if-absent request to initialize an empty JSON map at the attribute "document"
    // 4. Rerun the UpdateItemSpec call from the above try block
}

这是有效的,但不太理想,因为每次在表中添加新的主键时,都需要3次调用DynamoDB.我尝试了一些可以在Update Expressions中使用的attribute_not_exists函数,但是无法按照我想要的方式工作.

任何发电机专家在这里有什么想法可以做到吗?

解决方法

我收到了亚马逊支持的一个答案,实际上是不可能通过一个电话来完成这个.他们建议通过在put-if-absent请求中使用所需的JSON映射而不是空的映射,将新的主键的属性从3添加到2来减少呼叫次数.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读