entity-framework - Entity Framework 代码优先中的唯一约束

标签 entity-framework code-first unique-constraint

问题

是否可以使用流畅语法或属性来定义属性的唯一约束?如果没有,解决方法是什么?

我有一个带有主键的用户类,但我想确保电子邮件地址也是唯一的。不直接编辑数据库是否可以实现?

解决方案(基于马特的回答)

public class MyContext : DbContext {
    public DbSet<User> Users { get; set; }

    public override int SaveChanges() {
        foreach (var item in ChangeTracker.Entries<IModel>())
            item.Entity.Modified = DateTime.Now;

        return base.SaveChanges();
    }

    public class Initializer : IDatabaseInitializer<MyContext> {
        public void InitializeDatabase(MyContext context) {
            if (context.Database.Exists() && !context.Database.CompatibleWithModel(false))
                context.Database.Delete();

            if (!context.Database.Exists()) {
                context.Database.Create();
                context.Database.ExecuteSqlCommand("alter table Users add constraint UniqueUserEmail unique (Email)");
            }
        }
    }
}

最佳答案

据我所知,目前还没有办法使用 Entity Framework 来做到这一点。然而,这不仅仅是唯一约束的问题......您可能还想创建索引、检查约束,还可能需要触发器和其他构造。 Here's a simple pattern you can use使用代码优先设置,尽管不可否认它不是与数据库无关的:

public class MyRepository : DbContext {
    public DbSet<Whatever> Whatevers { get; set; }

    public class Initializer : IDatabaseInitializer<MyRepository> {
        public void InitializeDatabase(MyRepository context) {
            if (!context.Database.Exists() || !context.Database.ModelMatchesDatabase()) {
                context.Database.DeleteIfExists();
                context.Database.Create();

                context.ObjectContext.ExecuteStoreCommand("CREATE UNIQUE CONSTRAINT...");
                context.ObjectContext.ExecuteStoreCommand("CREATE INDEX...");
                context.ObjectContext.ExecuteStoreCommand("ETC...");
            }
        }
    }
}

另一种选择是,如果您的域模型是在数据库中插入/更新数据的唯一方法,您可以自己实现唯一性要求并将数据库排除在外。这是一个更可移植的解决方案,迫使您清楚代码中的业务规则,但会让您的数据库容易受到后门无效数据的影响。

关于entity-framework - Entity Framework 代码优先中的唯一约束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4413084/

相关文章:

c# - Javascript JSON仅序列化第一级

c# - 将 IList<Model> 从 View 传递到 Controller

entity-framework-4 - 当主键具有不同的名称时,如何使用 TPT 继承模型?

performance - 唯一约束如何影响 Postgres DB 中的写入性能

c# - Entity Framework 在一对一(可选/必需)关系中生成第二个左连接

c# - LINQ 和 AutoMapper

c# - 结合 EF Power Tools 和 .edmx 生成 CodeFirst Class 和 DB

entity-framework - 在 EF Code First 中启用级联删除而不暴露外键

ruby-on-rails - HABTM-唯一性约束

python - python类中UniqueConstraint的区别和使用