4

我首先使用 EF 代码作为我的项目的 ORM 技术,其中域模型具有如此多的原始数据类型集合。 存储原始数据类型集合的可能解决方案是什么,哪个是最佳解决方案

我知道的解决方案如下:

1.**创建一个不同的类,它将保存我们要使用其集合的原始数据类型的属性,而不是直接使用该原始类型的集合,而是使用新创建的类的集合,**更好地解释这种情况是****

实体框架代码优先原始集合

2.在单个列中序列化原始数据类型列表并使用一些分隔符来提取项目并编写自己的逻辑以将原始数据类型列表保存为单个列并使用逻辑将接收到的数据库值解析回各自的数据类型集合。

所以,以上两个是我已知的解决方案但我想知道哪个是存储原始数据类型集合的最佳解决方案

4

2 回答 2

2

在阅读并尝试了这么多选项之后,我发现上述两种策略都会增加复杂性、数据检索和保存。

因此,最好的方法(在我看来)是将原始数据类型的集合序列化为数据库中的字节数组并反序列化数据数据库:

Class Sample
{
    [NotMapped]
    Public List<String>Strings { get; set; }

    Public Byte[] StringBytes
    {
        get
        {
            var binaryfomrate = new BinaryFormatter();

            var memoryStream = new MemoryStream();

            binaryFormatter.searilze(ms, this.Strings);

            return ms.ToArray();
        }
        set
        {
            var binaryfomrater = new BinaryFormatter();
            this.Strings = binaryFormtter.Deserialize(value) as List<String>();
        }
    }
}
于 2013-04-02T05:53:44.450 回答
0

第一个解决方案是将集合类型存储在数据库中的最佳方式。换句话说,您必须为原始类型定义一个类,然后在两个类之间建立关系。

于 2013-04-01T08:13:07.943 回答