当使用AWS DynamoDB时,如果项目的大小小于400KB,可能会引发“put item size limit exception”异常。这是因为DynamoDB有一个限制,每个项目的大小不能超过400KB。
为了解决这个问题,你可以考虑以下几个方法:
import boto3
dynamodb = boto3.resource('dynamodb')
table = dynamodb.Table('your_table_name')
large_item = {
'id': '123',
'data': 'large_data'
}
small_items = [
{
'id': '123',
'data': 'small_data_1'
},
{
'id': '123',
'data': 'small_data_2'
}
]
# 将大的项目拆分成多个小的项目
table.put_item(Item=small_items[0])
table.put_item(Item=small_items[1])
import boto3
dynamodb = boto3.resource('dynamodb')
table = dynamodb.Table('your_table_name')
items = [
{
'id': '123',
'data': 'small_data_1'
},
{
'id': '123',
'data': 'small_data_2'
}
]
# 使用批处理操作写入多个项目
with table.batch_writer() as batch:
for item in items:
batch.put_item(Item=item)
import boto3
dynamodb = boto3.resource('dynamodb')
table = dynamodb.Table('your_table_name')
large_item = {
'id': '123',
'data': 'large_data'
}
small_items = [
{
'id': '123',
'data': 'small_data_1'
},
{
'id': '123',
'data': 'small_data_2'
}
]
# 将大的项目拆分成多个小的项目,并使用适当的分区和排序键
table.put_item(Item=small_items[0], ConditionExpression='attribute_not_exists(id)')
table.put_item(Item=small_items[1], ConditionExpression='attribute_not_exists(id)')
以上是几种解决“put item size limit exception”异常的方法。你可以根据你的具体需求选择适合你的方法。