我正在学习 Entity Framework/MVC 4,并开始关注一些关于创建存储库和抽象 EF 的教程。
我注意到的是 EF 似乎已经是 UnitOfWork/Repository 模式。
我尝试通过DbSet<TEntity>
用作基类来创建自定义 DbSet,但由于以下异常而无法使其工作:The type 'System.Data.Entity.DbSet<TEntity>' has no constructors defined
.
这是我正在尝试做的事情:
public class RolesDbSet : DbSet<Role>
{
public bool IsNameInUse(string name, int id = 0)
{
if (id == 0)
return this.Any(r => r.Name == name);
return this.Any(r => r.Name == name && r.ID != id);
}
}
public class MyEntities : DbContext
{
public MyEntities() : base("MyEntities")
{
Database.SetInitializer(new MyDevelopmentInitializer());
}
public RolesDbSet Roles { get; set; }
public DbSet<User> Users { get; set; }
public DbSet<Password> Passwords { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Configurations.Add(new UserConfiguration());
base.OnModelCreating(modelBuilder);
}
}
然后我就可以做到这一点:
bool inUse;
using (var db = new MyEntities())
{
inUse = db.Roles.IsNameInUse("Employee");
}
有没有办法做到这一点?