Amazon dynamodb 在dynamoDB中更新或创建嵌套元素

Amazon dynamodb 在dynamoDB中更新或创建嵌套元素,amazon-dynamodb,boto3,Amazon Dynamodb,Boto3,我想更新或创建DynamoDB项以获取下一个元素: { "id": 156, "date": 12323233.000, "countries": { "ua": 1, "ru": 2} } 我使用python和boto3。因此,我可以检查字段国家是否存在,如果不存在,则添加它。但这将意味着2 DB的请求 table.update_item( Key={ 'id': 156, 'date': da

我想更新或创建DynamoDB项以获取下一个元素:

{
    "id": 156, 
    "date": 12323233.000,
    "countries": {
        "ua": 1,
        "ru": 2}
}
我使用python和boto3。因此,我可以检查字段
国家是否存在,如果不存在,则添加它。但这将意味着2 DB的请求

table.update_item(
    Key={
        'id': 156,
        'date': date,
    },
    UpdateExpression='SET countries = if_not_exists(countries, :countries)',
    ExpressionAttributeValues={
        ':countries': {},
    },
)

table.update_item(
    Key={
        'id': 156,
        'date': date,
    },
    UpdateExpression='ADD countries.#country :inc',
    ExpressionAttributeNames={"#country": country},  
    ExpressionAttributeValues={
        ':inc': 1
    },
)

有没有办法将这两个请求合并成一个请求?

我最近不得不做类似的事情,花了一段时间才弄明白。如果一个页面在我的“完成”页面集中还不存在,我有一个要增加的计数。如果不是,则递增并将页码添加到集合中。花了一段时间才意识到可以“附加”到列表中,但必须“添加”到集合中

try:
    res = dbt.update_item(
        Key={'pk': 'doc3', 'sk': 'na'},
        ReturnConsumedCapacity='INDEXES', ReturnValues='ALL_NEW',
        ExpressionAttributeNames={
            '#count': 'count',
            '#done': 'done',
        },
        ExpressionAttributeValues={
            ':1': 1,
            ':page': page,
            ':pagelist': set([page]),
        },
        ConditionExpression="(NOT contains(done, :page))",
        UpdateExpression="ADD #done :pagelist, #count :1",
    )
    print(f'rand int page={page} count={res["Attributes"]["count"]}'
          f' CU={res["ConsumedCapacity"]["Table"]}')
except ClientError as err:
    if err.response['Error']['Code'] == 'ConditionalCheckFailedException':
        print('Already got page=%s (%s)' % (page, err))
    else:
        raise