c# – 实体框架代码第一,不是创建数据库

前端之家收集整理的这篇文章主要介绍了c# – 实体框架代码第一,不是创建数据库前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
以下是我的解决方案的概述:

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

猜你在找的C#相关文章