Amazon dynamodb 在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
{
"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