c# – 实体框架代码第一,不是创建数据库
发布时间:2020-12-15 06:56:01 所属栏目:百科 来源:网络整理
导读:以下是我的解决方案的概述: 这是我的PizzaSoftwareData类: namespace PizzaSoftware.Data{ public class PizzaSoftwareData : DbContext { public DbSetCustomer Customers { get; set; } public DbSetOrder Orders { get; set; } public DbSetProduct Pro
以下是我的解决方案的概述:
这是我的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(); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |