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之后才会有。否则需要自己另外下载

Database first with EntityFramework (Migration)安装和升级_第1张图片

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

Database first with EntityFramework (Migration)安装和升级_第2张图片

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

Database first with EntityFramework (Migration)安装和升级_第3张图片

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

Database first with EntityFramework (Migration)安装和升级_第4张图片

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

Database first with EntityFramework (Migration)安装和升级_第5张图片

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

Database first with EntityFramework (Migration)安装和升级_第6张图片

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

Database first with EntityFramework (Migration)安装和升级_第7张图片

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

Database first with EntityFramework (Migration)安装和升级_第8张图片

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

Database first with EntityFramework (Migration)安装和升级_第9张图片

10. “使用Update Database"命令可将数据模型,更新到任何一个数据库

 

数据库表和视图都很容易就实现了可升级,那么存储过程和其它数据类型怎么办呢?一个可以考虑的想法是,存储过程和其它数据类型可能和数据表有一些区别,数据表升级需要保持原来的数据什么的,而存储过程根本不需要太多考虑以前的状态,大可以每次升级将旧的删除然后重新产生新的存储过程。

1. 从数据库导出生成存储过程的sql scripts, 可取名为Create_StoredFunctions.sql

2. 建一个Sql目录,将脚本Create_StoredFunctions.sql放置于下

Database first with EntityFramework (Migration)安装和升级_第10张图片

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

Database first with EntityFramework (Migration)安装和升级_第11张图片

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

Database first with EntityFramework (Migration)安装和升级_第12张图片

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)
View Code

 

 

参考文献

1.SUPPORT FOR STORE FUNCTIONS (TVFS AND STORED PROCS) IN CODE FIRST (ENTITY FRAMEWORK 6.1)

http://blog.3d-logic.com/2014/04/09/support-for-store-functions-tvfs-and-stored-procs-in-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

https://www.simple-talk.com/dotnet/.net-framework/using-entity-framework-with-an-existing-database-data-access/

 

5.Entity Framework 6 Code First Migrations

http://community.sharpdevelop.net/blogs/mattward/archive/2013/12/23/EntityFramework6CodeFirstMigrations.aspx

 

6.Can you create sql views / stored procedure using Entity Framework 4.1 Code first approach

http://stackoverflow.com/questions/7667630/can-you-create-sql-views-stored-procedure-using-entity-framework-4-1-code-firs

 

你可能感兴趣的:(framework)