繁体   English   中英

实体框架代码第一个连接

[英]Entity Framework Code First connection

我在使用Code First方法连接到Entity Framework6中的数据库时遇到了一些麻烦。

我没有连接到在App_Data文件夹中创建的本地数据库,而是将连接字符串设置为指向SQL Server中的空数据库(无表)。

这是我的连接字符串:

<add name="LiquorContext" connectionString="Data Source=.; Initial Catalog=MVC_Code_First;User ID=sa; Password=*******;" providerName="System.Data.SqlClient" />

每当在我的ViewModel中调用此行时,我得到“System.ArgumentNullException:Value不能为null。参数名称:source”错误:

var users = context.Users.ToList();

这可能是我的Seed方法没有被调用,因为我在那里放置了一个断点,但从未到达过?

这是我的Context类:

public class LiquorContext : DbContext
{
    public LiquorContext()
        : base("LiquorContext")
    {

    }

    public DbSet<ExampleUser> Users;

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        modelBuilder.Conventions.Remove<System.Data.Entity.ModelConfiguration.Conventions.PluralizingTableNameConvention>();
    }
}

这是我的ContextInitializer:

public class LiquorContextInitializer : DropCreateDatabaseIfModelChanges<LiquorContext>
{
    protected override void Seed(LiquorContext context)
    {
        var users = new List<ExampleUser>()
        {
            new ExampleUser { Name="a", Surname="b"},
            new ExampleUser { Name="c", Surname="d"},
            new ExampleUser { Name="e", Surname="f"},
            new ExampleUser { Name="g", Surname="h"}
        };
        foreach (var user in users)
        {
            context.Users.Add(user);
        }
        context.SaveChanges();
    }
}

在这里,我在Global.asax文件中调用Initializer:

protected void Application_Start()
    {
        Database.SetInitializer<LiquorContext>(new LiquorContextInitializer());
        AreaRegistration.RegisterAllAreas();
        FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
        RouteConfig.RegisterRoutes(RouteTable.Routes);
        BundleConfig.RegisterBundles(BundleTable.Bundles);
    }

任何帮助,将不胜感激。 谢谢

在我的LiquorContext类中,我有DbSet <>如下:

public DbSet<ExampleUser> Users;

通过添加{get; 组; 如下,它有效:

public DbSet<ExampleUser> Users { get; set; }

没有更多信息很难说。 您是否在构造函数中为上下文设置了数据库初始值设定项? 这可能有所帮助:

http://www.codeproject.com/Articles/794187/Various-Strategies-to-Initialize-Database-in-Entit

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM