繁体   English   中英

首先是实体框架代码,而不是创建数据库

[英]Entity Framework code first, isn't creating the database

以下是我的解决方案外观的概述:

在此处输入图片说明

这是我的PizzaSoftwareData类:

namespace PizzaSoftware.Data
{
    public class PizzaSoftwareData : DbContext
    {
        public DbSet<Customer> Customers { get; set; }
        public DbSet<Order> Orders { get; set; }
        public DbSet<Product> Products { get; set; }
        public DbSet<User> Users { get; set; }
    }
}

根据Scott Guthrie博客上的示例,您必须在应用程序的开头运行此代码才能创建/更新数据库架构。

Database.SetInitializer<PizzaSoftwareData>(new CreateDatabaseIfNotExists<PizzaSoftwareData>());

我正在从PizzaSoftware.UI中的Program.cs运行该行代码。

namespace PizzaSoftware.UI
{
    static class Program
    {
        /// <summary>
        /// The main entry point for the application.
        /// </summary>
        [STAThread]
        static void Main()
        {
            Application.EnableVisualStyles();
            Application.SetCompatibleTextRenderingDefault(false);
            Database.SetInitializer<PizzaSoftwareData>(new CreateDatabaseIfNotExists<PizzaSoftwareData>());
            Application.Run(new LoginForm());
        }
    }
}

谁能告诉我为什么数据库没有创建表?

这是我的App.config文件中的连接字符串:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <connectionStrings>
    <add name="PizzaSoftwareData"
         connectionString="Data Source=.\SQLEXPRESS;Initial Catalog=SaharaPizza;Integrated Security=True;Pooling=False"
         providerName="System.Data.Sql" />
  </connectionStrings>
</configuration>

当您需要访问数据库时,将执行初始化程序。 如果要在应用程序上创建数据库,请使用以下两种方法之一:

context.Database.Initialize(true);

或不使用初始化程序并调用:

context.Database.CreateIfNotExists();

而不是将此代码放入main方法中:

Database.SetInitializer<PizzaSoftwareData>(new CreateDatabaseIfNotExists<PizzaSoftwareData>());

将其放入DBContext:

namespace PizzaSoftware.Data
{
public class PizzaSoftwareData : DbContext
{
        public PizzaSoftwareData()
        : base("name=PizzaSoftwareData")
        {
        Database.SetInitializer<PizzaSoftwareData>(new CreateDatabaseIfNotExists<PizzaSoftwareData>());
        }
        public DbSet<Customer> Customers { get; set; }
        public DbSet<Order> Orders { get; set; }
        public DbSet<Product> Products { get; set; }
        public DbSet<User> Users { get; set; }
    }
}

暂无
暂无

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

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