首先在Entity框架代码中存储原始数据类型集合的最佳方法

时间:2013-04-01 08:04:23

标签: entity-framework entity-framework-4 ef-code-first entity-framework-4.1 entity-framework-5

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

我知道的解决方案如下:

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

Entity Framework Code First primitive collections

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

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

2 个答案:

答案 0 :(得分: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>();
        }
    }
}

答案 1 :(得分:0)

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