如何在DynamoDB中存储具有重复项的字符串列表

时间:2015-03-26 00:21:59

标签: .net amazon-dynamodb aws-sdk

使用适用于.net的AWS开发工具包我正在尝试保存非唯一字符串列表。这个列表不是主要的哈希或任何东西,我只是希望能够按顺序引用它们并包含重复项。

模型

[DynamoDBTable("RMS.Accounts")]
public class Account
{
    [DynamoDBHashKey]
    public int Id { get; set; } 
    public string SomeValue { get; set; }
    public List<string> MoreValues{ get; set; }

    public Account()
    {
        // set default value
        MoreValues= new List<string>();
    }
}

控制器

Account account = new Account();
account.SomeValue = "testvalue";
account.MoreValues.Add("value1");
account.MoreValues.Add("value1");

var client = new AmazonDynamoDBClient();
var context = new DynamoDBContext(client);
context.Save(account, new DynamoDBOperationConfig() { SkipVersionCheck = true });

当我运行上面的代码时,我得到:

"An exception of type 'Amazon.DynamoDBv2.AmazonDynamoDBException' occurred in Apfm.RMS.Common.dll but was not handled in user code

Additional information: One or more parameter values were invalid: Input collection [value1, value1] contains duplicates.

我已经阅读了我可以得到的所有内容,但无法找到解决方法。也许我需要使用其他类型的集合,因此Dynamo知道这些项目不需要是唯一的。

1 个答案:

答案 0 :(得分:5)

查看this blog post,详细说明.NET SDK如何将List<string>HashSet<string>等.NET类型转换为DynamoDB数据类型。

简而言之,SDK默认为V1转换架构,其中List<string>存储为DynamoDB SS类型,不允许重复项。您想切换到使用V2转换架构。这可以通过多种方式完成:

1.设置应用程序的转换:

<configSections> <section name="aws" type="Amazon.AWSSection, AWSSDK"/> </configSections> <aws> <dynamoDB conversionSchema="V2" /> </aws>

2.在上下文中设置转换:

var context = new DynamoDBContext(client, new DynamoDBContextConfig { Conversion = DynamoDBEntryConversion.V2 });

3.设置操作的转换:

context.Save(account, new DynamoDBOperationConfig { Conversion = DynamoDBEntryConversion.V2 });

这些方法逐步细化。切换转换模式将改变某些类型的存储方式(博客文章对此进行了详细介绍),因此请考虑这一点。