我試圖通過方法Seed在數據庫中插入一些默認值。所有代碼看起來都完全正確,據我所知。但是在運行update-database
命令後,沒有按預期的方式記錄新的記錄。可能我錯過了一些細節。你能否告訴我如何解決這個問題?EF CodeFirst種子方法不要在數據庫中做任何更改
public class JwtContext : DbContext
{
public JwtContext() : base("name=Jwt")
{
Database.SetInitializer(new JwtDbInitializer<JwtContext>());
}
public virtual DbSet<Audience> Audience { get; set; }
public virtual DbSet<Roles> Roles { get; set; }
public virtual DbSet<Users> Users { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<Roles>()
.HasMany(e => e.Users)
.WithRequired(e => e.Roles)
.HasForeignKey(e => e.RoleId)
.WillCascadeOnDelete(true);
modelBuilder.Entity<Audience>()
.HasMany(e => e.Users)
.WithRequired(e => e.Audiences)
.HasForeignKey(e => e.AudienceId)
.WillCascadeOnDelete(true);
}
private class JwtDbInitializer<T> : DropCreateDatabaseAlways<JwtContext>
{
protected override void Seed(JwtContext context)
{
base.Seed(context);
var audience = new Audience
{
ClientId = "some_client_id",
Base64Secret = "some_secret",
Name = "Agromash.Api"
};
context.Audience.Add(audience);
context.SaveChanges();
IList<Roles> defaultRole = new List<Roles>();
defaultRole.Add(new Roles { Name = "Admin" });
defaultRole.Add(new Roles { Name = "Moder" });
defaultRole.Add(new Roles { Name = "User" });
foreach (var role in defaultRole)
{
context.Roles.Add(role);
}
context.SaveChanges();
var user = new Users { Email = "email", IsActive = true, Password = "password", RoleId = 1, AudienceId = 1 };
//SiteGlobal.Email, Password = SiteGlobal.Password
context.Users.Add(user);
context.SaveChanges();
}
}
}
更新數據庫命令=>您使用的EF代碼首先遷移? –
@DanNguyen,是的,沒錯。 –