gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 04:32:16 26 4
gpt4 key购买 nike

问题

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

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

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

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/

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