阻止 EF 5 生成属性

本文关键字:属性 EF 阻止 | 更新日期: 2023-09-27 18:30:27

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

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

即:

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 正在为该列自动生成一个成员,所以我只剩下两个。

阻止 EF 5 生成属性

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

public string BigComplexObjectString { get; set; }

然后执行以下操作:

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

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

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

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

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

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

在 edmx 中有一个更好的"cusom 信息"位置会很棒,但我们没有找到更好的即时信息。