Database first with EntityFramework (Migration)安装和升级
最近看了国外几个项目,发现用EntityFramework做Code First的项目现在很流行。
最让我有兴趣的一个功能则是,EntityFramework对于数据库的安装和升级的无缝完美支持,且很容易。
当然现在很多项目都是Dabase Frist出来的,也就是先有数据库后有C#代码,而且数据库当中一般都包含stored procedure(存储过程),user-defined table什么的。
那EntityFramework 的migration是否也支持了?最近试了一下,找到了一个方法但不一定是最优解,供参考。
1. “升级VS2013到Update4”,使用database first我们需要用到Entity Framework Power Tool Beta4. 这个只有升级了VS2013之后才会有。否则需要自己另外下载

2. “引用EntityFramework”, 建立一个Class Library项目"DataAccess",右击项目名,通过Nuget来引用EntityFramework

3. “加入Item,ADO.NET Entity Data Model”, 右击上面新加的项目“DataAccess”,在弹出菜单选择“Add New Item”。在Data分类中选择“ADO.NET Entity Data Model”。(可在项目下建一个DataModel的目录,然后右击该目录,选择“Add New Item”,这样数据模型可以建于该目录下)

4. “选择Code First From Database”,这个选项只有完成了第一步才会出现。不要选择“EF Designer From Database”,这个是不支持升级的。

5. “连接数据库”, Wizard会跳出窗口指定一个要连接的的数据库。输入用户名,密码

6. “生成数据模型”, 选择需要逆向工程的表和视图(大家可能看到了,这里根本没有存储过程或其它类型的数据选项,怎么解决?微软没告诉我们,我查了些资料找到了一个解决方案,后面将提到)

7. “打开Package Management Console”, 在Tool-->Nuget Package Manager中打开“Package Management Console

8."Enable Migration", 在“Package Management Console”中 敲入命令Enable-Migrations –ContextTypeName [ContextName], [ContextName]名字可以自己取。这个命令执行完后会在项目中自动添加“Migrations”目录,升级记录都将放在这个目录之下


9. "Add Migration", 在“Package Management Console”中 敲入命令 Add-Migration Initial [–IgnoreChanges], –IgnoreChanges 是可选参数,如果是针对已有的数据库产生升级则需要使用,如果是空的数据库则不需要该参数。 这个命令将会在“Migrations” 目录下生成创建初始化版本的数据库的c#代码


10. “使用Update Database"命令可将数据模型,更新到任何一个数据库
数据库表和视图都很容易就实现了可升级,那么存储过程和其它数据类型怎么办呢?一个可以考虑的想法是,存储过程和其它数据类型可能和数据表有一些区别,数据表升级需要保持原来的数据什么的,而存储过程根本不需要太多考虑以前的状态,大可以每次升级将旧的删除然后重新产生新的存储过程。
1. 从数据库导出生成存储过程的sql scripts, 可取名为Create_StoredFunctions.sql
2. 建一个Sql目录,将脚本Create_StoredFunctions.sql放置于下

3.为了方便使用,可创建一个Resource文件,将Create_StoredFunctions.sql拖入资源文件当中

4.在Up函数中调用,资源文件,执行Create_StoredFunctions.sql脚本来创建存储过程

5. 相应的在Down函数调用中可以调用Delete_StoredFunctions.sql脚本来删除所有的存储过程
删除脚本可参看下面
/* Drop all non-system stored procs */
DECLARE @name VARCHAR(128)
DECLARE @SQL VARCHAR(254) SELECT @name = (SELECT TOP 1 [name] FROM sysobjects WHERE [type] = 'P' AND category = 0 ORDER BY [name]) WHILE @name is not null
BEGIN
SELECT @SQL = 'DROP PROCEDURE [dbo].[' + RTRIM(@name) +']'
EXEC (@SQL)
PRINT 'Dropped Procedure: ' + @name
SELECT @name = (SELECT TOP 1 [name] FROM sysobjects WHERE [type] = 'P' AND category = 0 AND [name] > @name ORDER BY [name])
END
GO /* Drop all functions */
DECLARE @name VARCHAR(128)
DECLARE @SQL VARCHAR(254) SELECT @name = (SELECT TOP 1 [name] FROM sysobjects WHERE [type] IN (N'FN', N'IF', N'TF', N'FS', N'FT') AND category = 0 ORDER BY [name]) WHILE @name IS NOT NULL
BEGIN
SELECT @SQL = 'DROP FUNCTION [dbo].[' + RTRIM(@name) +']'
EXEC (@SQL)
PRINT 'Dropped Function: ' + @name
SELECT @name = (SELECT TOP 1 [name] FROM sysobjects WHERE [type] IN (N'FN', N'IF', N'TF', N'FS', N'FT') AND category = 0 AND [name] > @name ORDER BY [name])
END
GO /* Drop all table_schema */
DECLARE @DropSQL nvarchar(max) SELECT @DropSQL = coalesce(@DropSQL + ',', 'DROP TABLE ') + quotename(table_schema) + '.' + quotename(table_name) FROM INFORMATION_SCHEMA.Tables T WHERE T.TABLE_TYPE = 'BASE TABLE' execute(@DropSQL)
参考文献
1.SUPPORT FOR STORE FUNCTIONS (TVFS AND STORED PROCS) IN CODE FIRST (ENTITY FRAMEWORK 6.1)
2. Code First to an Existing Database
https://msdn.microsoft.com/en-us/data/jj200620
3.Code First Migrations with an existing database
https://msdn.microsoft.com/en-us/data/dn579398.aspx
4.Using Entity Framework With an Existing Database: Data Access
5.Entity Framework 6 Code First Migrations
6.Can you create sql views / stored procedure using Entity Framework 4.1 Code first approach
Database first with EntityFramework (Migration)安装和升级的更多相关文章
- Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级
Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 5.安装Database软件 5. ...
- Oracle10G无图形安装及升级
Oracle10.2.0.1静默安装及升级到10.2.0.4 下载及解压好database和Disk1 环境配置: su - oracle vim ~/.bash_profile 保存. vim /d ...
- hive的安装和升级
目录 [toc] 安装 升级 安装 nohup hive –service hiveserver & 启动: sudo nohup ./hive --service metastore &am ...
- 在 Linux 虚拟机中手动安装或升级 VMware Tools
对于 Linux 虚拟机,您可以使用命令行工具手动安装或升级 VMware Tools. 本次Linux 虚拟机为CentOS6.5 先决条件开启虚拟机.确认客户机操作系统正在运行.由于 VMware ...
- 24.Mysql高级安装和升级
24.Mysql高级安装和升级24.1 Linux/Unix平台下的安装 24.1.1 安装包比较Linux下的Mysql安装包分为RPM包.二进制包.源码包3种.RPM包优点是安装简单,适合初学者: ...
- centos7.6环境zabbix3.2源码编译安装版升级到zabbix4.0长期支持版
zabbix3.2源码编译安装版升级到zabbix4.0长期支持版 项目需求: .2版本不再支持,想升级成4.0的长期支持版 环境介绍: zabbix服务端是编译安装的,数据库和web在一台机器上 整 ...
- Centos MySQL 5.7安装、升级教程
MySQL 5.7安装.升级笔记分享: 卸载当前的 MySQL 查看当前 MySQL 版本: ? 1 2 [root@coderknock ~]# mysql -V mysql Ver 14.14 D ...
- Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part2:clusterware安装和升级
Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part2:clusterware安装和升级 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 3.安装Clus ...
- 转载 在 Linux 虚拟机中手动安装或升级 VMware Tools
http://pubs.vmware.com/workstation-12/index.jsp?lang=zh_CN&topic=/com.vmware.ws.using.doc/GUID-0 ...
随机推荐
- Fedora 22中的Services and Daemons
Introduction Maintaining security on your system is extremely important, and one approach for this t ...
- C# OracleDBhelper
引用 using System.Configuration;using System.Data.OracleClient; 连接字符串 <connectionStrings> <ad ...
- My First Android Application Project 第一个安卓应用
一.前言: 安卓(Android):是一种基于Linux的自由及开放源代码的操作系统,主要用在移动设备上,如手机.平板电脑.其他的设备也有使用安卓操作系统,比如:电视机,游戏机.数码相机等等. 二.具 ...
- 今天有群友不是很清楚htm直接存数据库的危害,我简单举个例子
通过这个案例就知道为什么不要把原生的html放数据库了 常见的几种转码 常用的几种显示方法 只有原生html和最下面一种弹框了,变成了持久xss 如果是Ajax的方式,请用@Ajax.JavaS ...
- 大数据时代下的SQL Server第三方负载均衡方案----Moebius测试
一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 架构原理(Architecture) 测试环境(Environment) 安装Moebius( ...
- Hawk 1.2 快速入门2 (大众点评18万美食数据)
本文将讲解通过本软件,获取大众点评的所有美食数据,可选择任一城市,也可以很方便地修改成获取其他生活门类信息的爬虫. 本文将省略原理,一步步地介绍如何在20分钟内完成爬虫的设计,基本不需要编程,还能自动 ...
- c# 检测操作系统版本
我们通过System.Environment.OSVersion.Version获得操作系统的版本号,然后再根据版本号进行判断操作系统是什么版本 Version 类的属性 Operating syst ...
- Oracle从文件系统迁移到ASM存储
环境:RHEL 6.4 + Oracle 11.2.0.4 需求:数据库存储由文件系统迁移到ASM 数据库存储迁移到ASM磁盘组 1.1 编辑参数文件指定新的控制文件路径 1.2 启动数据库到nomo ...
- 利用Python进行数据分析(1) 简单介绍
一.处理数据的基本内容 数据分析 是指对数据进行控制.处理.整理.分析的过程. 在这里,“数据”是指结构化的数据,例如:记录.多维数组.Excel 里的数据.关系型数据库中的数据.数据表等. 二.说说 ...
- Entity Framework 教程——安装Entity Framework环境
安装Entity Framework环境 Entity Framework 5.0 API分布在两个地方,一个可在NuGet包管理器中找到,一个存在于.NET framework中..NET fram ...