他山之眼 2018-01-23
1、开启EF数据迁移功能
NuGet包管理器------>程序包管理控制台---------->Enable-Migrations

2、数据库上下文设置为迁移至最后一个版本
MigrateDatabaseToLatestVersion<数据库上下文,迁移配置文件>
using Models.Migrations;
namespace Models
{
public class AppDBContext : DbContext, IDisposable
{
static AppDBContext()
{
Database.SetInitializer<AppDBContext>(new MigrateDatabaseToLatestVersion<AppDBContext, Configuration>());
}
public AppDBContext()
: base("DefaultConnection")
{
Database.Log = GetLog; //获取EF执行的sql
}
/// <summary>
/// 释放资源
/// </summary>
public new void Dispose()
{
base.Dispose();
GC.SuppressFinalize(this);
}
/// <summary>
/// 析构函数
/// </summary>
~AppDBContext()
{
base.Dispose();
}
private void GetLog(string sql)
{
//日志输出到控制台
System.Diagnostics.Debug.Write(sql);
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
//解决EF动态建库数据库表名变为复数问题
modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
}
}3、设置迁移配置文件,允许自动迁移和允许迁移时数据丢失(只适用于开发环境)
namespace Models.Migrations
{
using System;
using System.Data.Entity;
using System.Data.Entity.Migrations;
using System.Linq;
internal sealed class Configuration : DbMigrationsConfiguration<Models.AppDBContext>
{
public Configuration()
{
AutomaticMigrationsEnabled = true;
AutomaticMigrationDataLossAllowed = true;
ContextKey = "Models.AppDBContext";
}
protected override void Seed(Models.AppDBContext context)
{
// This method will be called after migrating to the latest version.
// You can use the DbSet<T>.AddOrUpdate() helper extension method
// to avoid creating duplicate seed data.
}
}
}实体变动,不再需要手动迁移,数据库将自动更新,AutomaticMigrationDataLossAllowed 设置为true迁移可能导致数据丢失
EF可以配置Oracle数据库,但不知道为什么一直配置不好。其实可以使用使用NUGET管理程序包,自动配置数据库,但需要注意的时,需要安装两个包,而并不是一个,我一直以为时一个,但已启动程序就会出错。