实体框架数据库种子不播种

时间:2013-03-13 15:41:11

标签: c# asp.net asp.net-mvc entity-framework initialization

我对EF很新。我正在尝试使用MVC 4覆盖自定义初始化程序中的Seed方法。

问题是当EF创建数据库时,我没有在我的Admins表中找到任何初始记录。这是我的代码:

namespace FP.Domain.Configurations
{
    public class InitializeSeed : DropCreateDatabaseIfModelChanges<EFDbContext>
    {
        protected override void Seed(EFDbContext context)
        {
            context.Admins.Add(new Admins
            {                
                Username = "admin",
                Password = "admin123456",
            });
            base.Seed(context);
        }
    }
}

这是我的控制器:

namespace FP.WebUI.Controllers
{
    public class AdminController : Controller
    {       
        public ViewResult Login()
        {
            Database.SetInitializer(new InitializeSeed());
            return View();
        }

    }
}

这是我的Admins实体:

namespace FP.Domain.Entities
{
    public class Admins
    {
        public int ID { get; set; }
        public string Username { get; set; }
        public string HashedPassword { get; set; }

        private string _password;
        public string Password
        {
            set
            {
                this._password = value;
                byte[] tempSrc = ASCIIEncoding.ASCII.GetBytes(_password);                    
                HashedPassword = Convert.ToBase64String(new SHA256CryptoServiceProvider().ComputeHash(tempSrc));
            }
        }
    }
}

1 个答案:

答案 0 :(得分:3)

您没有将更改保存到数据库。请注意,Seed的默认实现不执行任何操作。

尝试在种子中添加对SaveChanges的调用。

protected override void Seed(EFDbContext context)
{
    context.Admins.Add(new Admins
    {                
        Username = "admin",
        Password = "admin123456",
    });
    base.Seed(context);
    context.SaveChanges();
}