gpt4 book ai didi

c# - DynamoDB 数据模型中的 map 列表

转载 作者:行者123 更新时间:2023-12-05 02:11:57 25 4
gpt4 key购买 nike

我们有一个具有定义属性的数据模型,但其中一个属性允许动态元数据( map 或字典列表)。使用文档模型,此属性可以很好地映射到 Document 的列表。 ,但是,当我无法使用 DataModel 将此动态属性映射到任何内容时.有没有办法将动态数据映射到模型类属性内的文档?

尝试将其映射为字典列表(匹配元数据的结构)失败并出现以下错误:

public List<Dictionary<string, object>> Events { get; set; }

Unable to convert [Amazon.DynamoDBv2.DocumentModel.Document] of type Amazon.DynamoDBv2.DocumentModel.Document to System.Collections.Generic.Dictionary`

使用 List<Document> 的类型给我最接近的,它现在列出了 39 个文档,但所有文档都有 0 个键,0 个值。

public List<Document> Events { get; set; }

例如:

document["Events"].AsListOfDocument().First(); // works, contains the keys and values

datamodel.Events.First(); // does not work, it is an empty document

最佳答案

我知道这是一个相当古老的问题,但希望这可以帮助其他正在努力解决这个问题的人。

嗨德文,<​​/p>

如果您尝试创建对象以将其发送到您的 DynamoDB,您可以尝试映射任意数据,正如 AWS documentation for .NET 中所述

这是文档中的代码:

try
{
DynamoDBContext context = new DynamoDBContext(client);

// 1. Create a book.
DimensionType myBookDimensions = new DimensionType()
{
Length = 8M,
Height = 11M,
Thickness = 0.5M
};

Book myBook = new Book
{
Id = 501,
Title = "AWS SDK for .NET Object Persistence Model Handling Arbitrary Data",
ISBN = "999-9999999999",
BookAuthors = new List<string> { "Author 1", "Author 2" },
Dimensions = myBookDimensions
};

context.Save(myBook);

在数据库中获得数据后,您可以将新 map 附加到列表中,其中包含以下内容:

var request = new UpdateItemRequest
{
TableName = "TableName",
Key = new Dictionary<string, AttributeValue>() { { "PartitionKey", new AttributeValue { S = "value" } } },
ExpressionAttributeNames = new Dictionary<string, string>()
{
{ "#A", "A" }
},
ExpressionAttributeValues = new Dictionary<string, AttributeValue>()
{
{
":val", new AttributeValue
{
L = new List<AttributeValue>()
{
{
new AttributeValue
{
M = new Dictionary<string, AttributeValue>()
{
{ "Address", new AttributeValue{S = "Value" } },
{ "Latitude", new AttributeValue { S = position.Latitude.ToString() } },
{ "Longitude", new AttributeValue { S = position.Longitude.ToString() } }
}
}
}
}
}
}
},
UpdateExpression = "SET #A = list_append(#A, :val)"
};

try
{
var response = await client.UpdateItemAsync(request);

}
catch (Exception ex)
{
Debug.WriteLine(ex.Message);
}

这对我有用,我希望对其他人也有用。

...

PS:顺便说一句,这是我在 Stackoverflow 中的第一个答案,当我多次来到这里寻求答案时,尝试做出贡献感觉很好,这节省了我的时间 jajajaja

关于c# - DynamoDB 数据模型中的 map 列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56741960/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com