【问题标题】:Entity Framework code first, isn't creating the database首先是实体框架代码,不是创建数据库
【发布时间】:2026-01-06 08:05:01
【问题描述】:

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

这是我的 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>

【问题讨论】:

    标签: c# ef-code-first entity-framework-4.1


    【解决方案1】:

    初始化程序在您需要访问数据库时执行。如果您想在应用程序启动时创建数据库,请使用:

    context.Database.Initialize(true);
    

    或者不要使用初始化器和调用:

    context.Database.CreateIfNotExists();
    

    【讨论】:

    • 这条线会去哪里?
    • @mmcrae:初始化应用程序。这取决于应用程序类型。
    • 在我的情况下,Database.Initialize(true) 以某种方式抛出异常:抛出了“System.*Exception”类型的异常。 Database.CreateIfNotExists() - 工作正常。
    【解决方案2】:

    不要将此代码放入 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; }
        }
    }
    

    【讨论】: