【问题标题】:EF Code first Generic Entity & EntityTypeConfigurationEF Code first Generic Entity & EntityTypeConfiguration
【发布时间】:2015-01-05 09:38:50
【问题描述】:

我即将为我的实体创建通用 EntityEntityTypeConfiguration。这是我的课程:

IEntity

public interface IEntity<T>
{
    T Id { get; set; }
}

public interface IAuditableEntity<T>
{
    DateTime CreatedAt { get; set; }
    Membership.User CreatedBy { get; set; }
    int? CreatedById { get; set; }
    DateTime? DeletedAt { get; set; }
    Membership.User DeletedBy { get; set; }
    int? DeletedById { get; set; }
    T RevisionParentId { get; set; }
    bool isLastVersion { get; set; }
}

Entity.cs

public abstract class BaseEntity
{

}

public abstract class Entity<T> : BaseEntity, IEntity<T>
{
    public virtual T Id { get; set; }
}

public abstract class AuditableEntity<T> : Entity<T>, IAuditableEntity<T>
{
    public DateTime CreatedAt { get; set; }
    public virtual Membership.User CreatedBy { get; set; }
    public int? CreatedById { get; set; }
    public DateTime? DeletedAt { get; set; }
    public virtual Membership.User DeletedBy { get; set; }
    public int? DeletedById { get; set; }
    public T RevisionParentId { get; set; }
    public bool isLastVersion { get; set; }
}

问题是当我尝试定义 AuditableEntity 的通用 EntityTypeConfiguration 时,因为:

public class AuditableEntityConfig<T> : System.Data.Entity.ModelConfiguration.EntityTypeConfiguration<T> where T : AuditableEntity<int>
{
    public AuditableEntityConfig()
    {
        HasOptional(x => x.CreatedBy).WithMany().HasForeignKey(x => x.CreatedById);
        HasOptional(x => x.DeletedBy).WithMany().HasForeignKey(x => x.DeletedById);
        Property(x => x.DeletedAt).IsOptional();
        Property(x => x.RevisionParentId).IsOptional();
    }
}

public class User : AuditableEntity<long>
{

}

你看我必须AuditableEntity&lt;int&gt; 这是错误的,我不知道要替换什么才能让它工作。 AuditableEntity&lt;int&gt; 应该类似于 AuditableEntity&lt;T&gt; 并且 T 可以是 string、int、guid、long、...

更新 正如迈克回答所建议的那样,我进行了更改并更新了我的问题:

public class User : AuditableEntity<int>
{
    [Index("IX_uniqueUsername", IsUnique = true)]
    public string Username { get; set; }
    public string Password { get; set; }
    public string Email { get; set; }
    public bool Active { get; set; }
    public virtual List<Role> Roles { get; set; }
    public virtual List<UserGroup> Groups { get; set; }
    public virtual UserProfile Profile { get; set; }
    public bool isSuperAdmin { get; set; }
}

public class UserConfig : AuditableEntityConfig<User, int>
{
    public UserConfig()
    {
        ToTable("Account_Users");
        Property(x => x.Username).HasMaxLength(200).IsRequired();
        Property(x => x.Password).HasMaxLength(200).IsRequired();
        Property(x => x.Email).HasMaxLength(200);
        HasMany(x => x.Roles).WithMany(x => x.Users).Map(x =>
        {
            x.ToTable("Account_UserRoles");
            x.MapLeftKey("UserId");
            x.MapRightKey("RoleId");
        });
        HasMany(x => x.Groups).WithMany(x => x.Users).Map(x =>
        {
            x.ToTable("Account_UserGroups");
            x.MapLeftKey("UserId");
            x.MapRightKey("GroupId");
        });
    }
}

我现在收到 RevisionParentId 属性的此错误:

The type 'TK' must be a non-nullable value type in order to use it as parameter 'T' in the generic type or method 'System.Data.Entity.ModelConfiguration.Configuration.StructuralTypeConfiguration<TStructuralType>.Property<T>(System.Linq.Expressions.Expression<System.Func<TStructuralType,T>>)

在这一行:

Property(x => x.RevisionParentId).IsOptional();

【问题讨论】:

  • 你到底想“工作”什么。如果您的实体类型配置是泛型类型 T,那么映射到 RevisionParentId 的字段应该在数据库中是什么数据类型?你想通过使这个字段的类型通用来实现什么?
  • RevisionParentId 是同一实体的自引用外键。例如:我有一个Post 实体,它的Id 类型为T。所以RevisionParentId 也应该是T 类型

标签: c# asp.net entity-framework ef-code-first


【解决方案1】:

where T : AuditableEntity&lt;T&gt; 将导致递归类型检查。请尝试

更新

public class AuditableEntityConfig<T, TK> : System.Data.Entity.ModelConfiguration.EntityTypeConfiguration<T>
    where T : AuditableEntity<TK> where TK : struct { }

【讨论】:

  • 试试我更新的解决方案。在AuditableEntity&lt;TK&gt;之后添加了where TK : struct
猜你喜欢
  • 2011-08-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-09-27
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多