gpt4 book ai didi

c# - 告诉 EF 6 忽略私有(private)属性

转载 作者:行者123 更新时间:2023-11-30 22:09:02 25 4
gpt4 key购买 nike

我正在使用 Entity Framework 6.0.2 将一些简单的手动编码模型映射到现有数据库结构。目前的主要模型是:

public class Occurrence
{
public int ID { get; set; }
public Guid LegacyID { get; set; }
public string Note { get; set; }
public virtual ICollection<OccurrenceHistory> History { get; set; }
}

(OccurrenceHistory 模型与此并不相关,但该部分工作正常,EF 会为此模型加载子记录。)

映射很简单,我尽量做到明确(因为随着应用程序的增长,会有一些不那么直观的映射):

public class OccurrenceMap : EntityTypeConfiguration<Occurrence>
{
public OccurrenceMap()
{
ToTable("Occurrence");
HasKey(o => o.ID);
Property(o => o.ID).IsRequired().HasColumnName("ID");
Property(o => o.LegacyID).IsRequired().HasColumnName("LegacyID");
Property(o => o.Note).IsUnicode().IsOptional().HasColumnName("Note");
}
}

但是如果我向模型添加私有(private)属性,EF 会尝试将其映射到数据库。像这样:

private OccurrenceHistory CurrentHistory { get; set; }

(在模型内部,我会有一些逻辑来维护该字段,用于其他私有(private)操作。)当 EF 生成 SELECT 语句时,它最终会查找名为 CurrentHistory_ID< 的列 这当然不存在。

我可以公开该属性并将映射设置为忽略它:

Ignore(o => o.CurrentHistory);

但我不希望该属性公开。该模型将在内部跟踪应用程序代码不应看到的一些信息。

有没有办法告诉 EF 忽略所有私有(private)成员?即使它是基于每张 map ?我特别想在不必向模型本身添加 EF 数据注释的情况下执行此操作,因为这不仅会有点泄漏抽象(对持久性一无所知的模型会在其上具有持久性信息),而且还意味着包含模型的域核心程序集将随处携带对 EntityFramework.dll 的引用,这并不理想。

最佳答案

一位同事向我指出了 a blog post这导致了一种非常实用的方法。

所以我拥有的是私有(private)属性(property):

private OccurrenceHistory CurrentHistory { get; set; }

问题的核心是我不能在我的映射中使用它:

Ignore(o => o.CurrentHistory);

因为很明显,该属性是私有(private)的,在此上下文中无法访问。博客文章建议公开引用私有(private)属性的公共(public)静态表达式:

private OccurrenceHistory CurrentHistory { get; set; }
public static readonly Expression<Func<Occurrence, OccurrenceHistory>> CurrentHistoryExpression = o => o.CurrentHistory;

然后我可以在映射中引用那个:

Ignore(Occurrence.CurrentHistoryExpression);

与任何事物一样,它有利有弊。但在这种情况下,我认为利远大于弊。

优点:

  • 域核心程序集不需要携带对 EntityFramework.dll 的引用。
  • 持久性映射完全封装在 DAL 程序集中。

缺点:

  • 模型需要公开一些关于其内部运作的信息。

con 破坏了封装,但只是轻微的。使用代码仍然无法访问该属性或其在实例上的值,它只能看到该属性存在 是静态的。这真的没什么大不了的,因为开发人员无论如何都可以看到它。我觉得封装的精神仍然保留在模型的任何给定实例上。

关于c# - 告诉 EF 6 忽略私有(private)属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21839131/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com