Entity Framework数据库初始化四种策略
2016-01-25 10:42
423 查看
策略一:数据库不存在时重新创建数据库
复制内容到剪贴板程序代码Database.SetInitializer<testContext>(new CreateDatabaseIfNotExists<testContext>());
策略二:每次启动应用程序时创建数据库
复制内容到剪贴板程序代码
Database.SetInitializer<testContext>(new DropCreateDatabaseAlways<testContext>());
策略三:模型更改时重新创建数据库
复制内容到剪贴板程序代码
Database.SetInitializer<testContext>(new DropCreateDatabaseIfModelChanges<testContext>());
策略四:从不创建数据库
复制内容到剪贴板程序代码
Database.SetInitializer<testContext>(null);
Entity Framework数据库初始化示例
复制内容到剪贴板程序代码
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using Web.Models.Mapping;
namespace Web.Models
{
public class testContext : DbContext
{
static testContext()
{
Database.SetInitializer<testContext>(null);
}
public testContext()
: base("Name=testContext")
{
}
public DbSet<Person> People { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Configurations.Add(new PersonMap());
}
}
}
相关文章推荐
- mysql 1449 : The user specified as a definer ('root'@'%') does not exist 解决方法
- Memcache 基础原理
- Oracle----sqlldr用法(转)
- Msql入门实战之下
- mysql中float,double,decimal的差别
- Oracle的model语句入门
- oracle相关知识2
- 脏读、不可重复读 共享锁、悲观锁
- mongodb 数据备份,还原笔记
- oracle普通知识
- SQL compute by 的使用 主要是针对与 GROUP BY 的区别
- Nginx配置srcache_nginx模块搭配Redis建立缓存系统
- 【转】ORACLE官方文档目录说明
- 往arm9平台移植sqlite3
- oracle数据库备份删除操作
- MySQL InnoDB存储引擎
- 分页sql
- mysql添加外键
- 管理员 修改MySQL 5.7.9 新版本的root密码方法以及一些新变化整理
- sql server 表值类型的使用