对于类似的数据库表,.Net EntityFramework 4.0中的继承

Ath*_*ras 6 .net c# inheritance entity-framework-4

我正在寻找以下问题的解决方案:

我有很多表在少数/无列中彼此区分(为什么发生这种情况并非如此,因为我没有设计所述数据库,也无法更改它).

示例:表用户:列{name,surname,age}表OldUser:列(name,surname,age,lastDateSeen}等

有没有办法在Visual Studio中向EntityFramework 4.0指示扩展由_name,_surname,_age字段及其相应属性组成的基类,以便我可以在代码中将该类用于批处理作业?

我目前的解决方案是创建这个类并使用转换器将持久对象的值传递给它的对象.它有效,但它不优雅,我不喜欢它.

我来自java/hibernate环境,这是基本功能.

(对于将来的引用,如果我希望类实现接口,可以做同样的事情吗?)

提前致谢.

Jos*_*off 1

由于您的 RDBMS(至少是 SQL Server 2008 及更早版本)不允许表继承,因此我建议您不要在 C# 的数据库模型中使用继承。当您无法控制表的设计时,特别建议这样做。

如果您实际上拥有那些将从抽象中受益的类的客户端,但无法控制数据库的设计,则应使用接口,因为数据库设计者可能会更改表,从而使您的 EF 类不再实现界面:

public interface IUser {
  public string Name { get; }
  // etc...
}

public class User : IUser {
  public string Name { get; set; }
  // etc...
}

public class OldUser : IUser {
  public string Name { get; set; }
  // rest of IUser
  public DateTime? LastSeenOn { get; set; }
}
Run Code Online (Sandbox Code Playgroud)