使用.NET SDK在DynamoDB中保留动态对象

时间:2017-03-12 13:40:30

标签: c# .net asp.net-core amazon-dynamodb

我尝试使用.NET SDK将以下类继承到DynamoDB:

public class MyClass
{
    public string Id { get; set; }

    public string Name { get; set; }

    public object Settings { get; set; }
}

问题在于Settings属性。它可以是任何类型的对象,我事先并不知道可能分配给它的是什么。当我尝试将其持久化到DynamoDB时,我得到以下异常:

System.InvalidOperationException: 'Type System.Object is unsupported, it has no supported members'

文档模型和对象持久性模型方法都会导致相同的异常。

有没有办法在DynamoDB中保留这些对象?其他数据库(如MongoDB和Azure DocumentDB)可以毫无问题地执行此操作,并且可以将它们反序列化为带有鉴别器的正确类型,或者作为动态JSON对象。

1 个答案:

答案 0 :(得分:4)

您可以使用此处记录的常规方法:https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/DynamoDBContext.ArbitraryDataMapping.html

这是我对任意对象的实现:

public class DataConverter : IPropertyConverter
{
    public object FromEntry(DynamoDBEntry entry)
    {
        var primitive = entry as Primitive;
        if (primitive == null || !(primitive.Value is String) || string.IsNullOrEmpty((string)primitive.Value))
            throw new ArgumentOutOfRangeException();
        object ret = JsonConvert.DeserializeObject(primitive.Value as string);
        return ret;
    }

    public DynamoDBEntry ToEntry(object value)
    {
        var jsonString = JsonConvert.SerializeObject(value);
        DynamoDBEntry ret = new Primitive(jsonString);
        return ret;
    }
}

然后像这样注释您的财产:

[DynamoDBProperty(typeof(DataConverter))]
public object data { get; set; }