c# - Entity Framework 代码首先,不是创建数据库

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

下面是我的解决方案的概览:

enter image description here

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

最佳答案

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

context.Database.Initialize(true);

或者不使用初始化器并调用:

context.Database.CreateIfNotExists();

关于c# - Entity Framework 代码首先,不是创建数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5414130/

相关文章:

c# - 在单个线程上启动第二个消息循环不是有效操作。改为使用 Form.ShowDialog

c# - 使用 linq 加载除另一个集合之外的集合

c# - 使用存储库模式实现 WCF 数据服务

asp.net - 在数据访问层使用HttpContext

c# - EF 代码首先 List<DateTime> 不创建表

c# - 在正则表达式替换中转义数字

c# - MSBuild 属性引用

c# - Entity Framework 代码第一个一对多级联错误

c# - EF4.1 - 属性在运行时评估为 null

wcf - EF 4.1 Code First - 使用新上下文/WCF 时未更新 FK 值的更改