2

我首先将 EF5 数据库与部分类一起使用。我的部分类中有一个属性,其中包含 n 个对象,该对象作为列存储在我的数据库中包含 XML 数据的列。当 EF 尝试使用自定义 getter/setter 读取/写入该对象时,我想处理该对象的序列化/反序列化。

是否可以在我的部分类中公开该列并使用 EF 对其进行映射,而无需为其自动生成属性?

IE:

public SomeObject BigComplexObject { get; set; } // forms etc in my app use this
public string BigComplexObjectString // when the EF tries to read/write the column, my custom getter/setter kicks in
{
    get { return this.BigComplexObject.ToXmlString(); }
    set { this.BigComplexObject  = new BigComplexObject(value); }
}

目前,EF 正在为该列自动生成一个成员,所以我只剩下两个。

4

2 回答 2

0

尝试改变逻辑。保留 EF 生成的属性,该属性将使用数据库中的 XML 字符串填充:

public string BigComplexObjectString { get; set; }

然后执行以下操作:

[NotMapped]
public SomeObject BigComplexObject
{
    get { return new SomeObject(this.BigComplexObjectString); }
    set { this.BigComplexObjectString = value.ToXmlString(); }
}

不要忘记添加 [NotMapped] 以指示 EF 忽略此属性。

于 2013-09-07T19:01:58.693 回答
0

好吧,我们对一个非常相似的案例使用了一个小技巧......

我们使用我们的...属性的属性面板(在 edmx 文件中)并在“文档”(摘要或详细描述)行中添加一些内容(可能不是最好的地方,但无论如何)。这可以通过您的 T4 文件访问。

因此,您可以在属性面板中编写类似“useXml”的内容,然后修改您的 tt 以在何时生成所需的代码(例如获取 .tt 文件中的信息)

if (edmProperty.Documentation != null && edmProperty.Documentation.Summary = "useXml")
  //generate something special

在 edmx 中有一个更好的“客户信息”位置会很棒,但我们暂时没有找到更好的地方。

于 2013-09-07T19:02:05.617 回答