dynamodb:如何在map中增加一个值

时间:2016-07-02 18:06:55

标签: amazon-dynamodb boto3

我正在尝试使用dynamodb维护带有值的地图名称

eg. {"scores": {"player-a": 10}}

我还希望使用increment运算符来执行原子增量。 但是,我可以找到关于如何使用/更新dynamodb地图的文档。 这是我到目前为止的python代码

 import boto3
 ddb = boto3.client('dynamodb')
 ddb.update_item(TableName='ledger', Key={'week': {'S': '06-12'}}, 
                 UpdateExpression='SET scores.player-a  = scores.player-a + :val', 
                 ExpressionAttributeValues={':val': {'N': '12'}})

1 个答案:

答案 0 :(得分:1)

DynamoDB更新项使用ExpressionAttributeNames来防止属性名称中的特殊字符在表达式中被误解释。

您的更新项目包含"播放器-a"作为一个关键的名称有" - " (连字符)。

ddb.update_item(
    TableName='ledger',
    Key={
        'week': {
            'S': '06-12'
        }
    }, 
    UpdateExpression='SET scores.#s = scores.#s + :val",  
    ExpressionAttributeNames={
        "#s": "player-a"
    },  
    ExpressionAttributeValues={
        ':val': {
            'N': '12'
        }
    }
)