繁体   English   中英

如何使用 Rust 将 append 元素添加到 DynamoDB 中的列表

[英]How to append elements to a list in DynamoDB using Rust

我正在努力在 Rust 中以编程方式使用list_append

我有一个名为Humidities的表:

{
 "id": 177,
 "Measurements": [
  49
 ]
}

我想添加元素。 例如:

{
 "id": 177,
 "Measurements": [
  49,
  53
 ]
}

这是 python 的有效解决方案,我在这里找到了它:

table = get_dynamodb_resource().Table("table_name")
result = table.update_item(
    Key={
        'hash_key': hash_key,
        'range_key': range_key
    },
    UpdateExpression="SET some_attr = list_append(some_attr, :i)",
    ExpressionAttributeValues={
        ':i': [some_value],
    },
    ReturnValues="UPDATED_NEW"
)
if result['ResponseMetadata']['HTTPStatusCode'] == 200 and 'Attributes' in result:
    return result['Attributes']['some_attr']

基于 python 解决方案我试过这个:

#[tokio::main]
async fn main() -> Result<(), Error> {
    let Opt { base } = Opt::from_args();
    let shared_config = make_config(base).await?;
    let client = Client::new(&shared_config);
    client
        .update_item()
        .table_name("Humidities")
        .key("id", AttributeValue::N(177.to_string()))
        .update_expression("SET i = list_append(Measurements, :i)")
        .expression_attribute_values("i", AttributeValue::N(53.to_string()))
        .send()
        .await?;
    Ok(())
}

然而,结果是:

Error: Unhandled(Error { code: Some("ValidationException"), message: Some("ExpressionAttributeValues contains invalid key: Syntax error; key: \"i\""), request_id: Some("05RSFGFJEEDPO7850LI2T91RGRVV4KQNSO5AEMVJF66Q9ASUAAJG"), extras: {} })

我究竟做错了什么?

这些示例仅演示如何添加单个项目: https://github.com/awslabs/aws-sdk-rust/blob/main/examples/dynamodb/src/bin/add-item.rs

我也试过这个:

#[tokio::main]
async fn main() -> Result<(), Error> {
    let Opt { base } = Opt::from_args();
    let shared_config = make_config(base).await?;
    let client = Client::new(&shared_config);
    client
        .update_item()
        .table_name("Humidities")
        .key("id", AttributeValue::N(177.to_string()))
        .update_expression("set #Measurements = list_append(#Measurements, :value)")
        .expression_attribute_names("#Measurements", "Measurements")
        .expression_attribute_values("value", AttributeValue::N(53.to_string()))
        .return_values(aws_sdk_dynamodb::model::ReturnValue::AllNew)
        .send()
        .await?;
    Ok(())
}

看看: Append 一个新的 object 到一个 JSON 数组在 DynamoDB 中使用 NodeJS

结果相同,值未知:

Error: Unhandled(Error { code: Some("ValidationException"), message: Some("ExpressionAttributeValues contains invalid key: Syntax error; key: \"value\""), request_id: Some("1A8VEOEVSB7LMAB47H12N7IKC7VV4KQNSO5AEMVJF66Q9ASUAAJG"), extras: {} }) 

我找到了解决方案。 有两个问题:

  • list_append 需要两个列表
  • expression_attribute_values expected :value而不是value

运行示例:

async fn main() -> Result<(), Error> {
    let Opt { base } = Opt::from_args();
    let shared_config = make_config(base).await?;
    let client = Client::new(&shared_config);
    client
        .update_item()
        .table_name("Humidities")
        .key("id", AttributeValue::N(177.to_string()))
        .update_expression("set #Measurements = list_append(#Measurements, :value)")
        .expression_attribute_names("#Measurements", "Measurements")
        .expression_attribute_values(
            ":value", // changed from "value" to ":value"
            AttributeValue::L(vec![AttributeValue::N(53.to_string())]), // use a vector of numbers instead of a number
        )
        .return_values(aws_sdk_dynamodb::model::ReturnValue::AllNew)
        .send()
        .await?;
    Ok(())
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM