devexpress entity framework 与 asp.net mvc的坑

发布于 2017-03-25  268 次阅读


最近在做一个使用ASP.NET MVC DEVEXPRESS和EF的OA模块 遇到不少问题这里记录一下:

1 如果项目中存在多个上下文类(DBContext的派生类),在做数据迁移的时候需要在不同目录下和对应类名分别启用Migration,具体指令可以参考:

  http://www.cnblogs.com/Jack-Blog/p/4699596.html?ptvd

 

 

 

前言

本人在阿里云申请了个免费的空间,之前已经存放了一个项目,由于之前一直没时间,近期比较有空,所以想开发个个人博客,但是由于阿里云没有给我们权限来新建数据库,因此只能在原有的数据库另外“瓜分”一部分空间来做个人博客的数据库,我是在之前的JackSite.Entities实体项目上开发,因此只需要在定义一个DbContext即可。

PS:本次讨论的使用范围通过EF6(低版本是否支持多数据上下文我并不了解)用一个数据库构造多个DbContext

 

实现目标

原本默认Migration的文件是在Migrations,我现在希望已如下的形式来存放

Migrations项目中添加文件夹AMigration,BMigration文件来区分不同的DbContext迁移文件。

 

设置多数据上下文

首先我查找了下资料并未发现有类似Move-Migrations或者Update-Migrations的命令,因此我设想是是否同样是通过Enable-Migrations进行设置 
通过google 搜索关键字Single Database Multiple DbContext 搜到确实和我想象的一致都是通过此命令来设置多个数据库上下文的迁移文件路径 在抱着试试看的态度,进行了如下命令输入:

 

  1. Enable-Migrations -ContextTypeName:JackSite.Entities.Models.StudyTime.JackDbContext -MigrationsDirectory:Migrations\StudyTimeMigrations

ContextTypeNameDbContext的位置,即DbContext的命名空间加上DbContext的名称 
MigrationsDirectory:需要迁移到的目标文件夹 
PS:注意MigrationsDirectory:Migrations\StudyTimeMigrations中的'\'不要打错如输成'/'可能会引发一些问题 
同样我们对另一个数据上下文进行设置

 

  1. Enable-Migrations -ContextTypeName:JackSite.Entities.Models.Blog.BlogDbContext -MigrationsDirectory:Migrations\BlogMigrations

PS:这里两个DbContext用的是同样的连接串

 

更新数据脚本

最后通过运行Add-Migrations命令

这里需要注意:如果我们只有一个数据上下文,通过Add-Migrations命令会自动选择唯一的DbContext,但是如果有多个DbContext,我们必须指定我们需要对那个DbContext进行修改

 

  1. Add-Migration -ConfigurationTypeName JackSite.Entities.Migrations.BlogMigrations.Configuration InitBlogDb

这里通过-ConfigurationTypeName指定Configuration 后面接着是Configuration的路径,然后接着是我们取得名字InitBlogDb 
EF会找到指定的Configuration,并添加XXXX_InitBlogDb,结构如下图所示:

 
最后通过Update-Database进行更新

同样,我们这里需要指定需要更新哪个Configuration

 

  1. Update-Database JackSite.Entities.Migrations.BlogMigrations.Configuration

  2 使用EF和ASP.NET MVC的时候,如果视图中没有绑定KEY,需要用一个Html.HiddenFor(m=>m.key)来绑定主键,这样方便在后续post回发中获取对象的key。然后由于ASP.NET是短连接,回发的model是重新创建的detached状态,需要重新attach到DbContext才能正确更新。     3 DEVEXPRESS的文件上传控件不适合asp.net mvc的附件随表单上传,直接用input type=file上传更简单方便,另外上传文件的表单form要加enctype="multipart/form-data"属性,并且input type=file元素要有不同的name属性,否则服务端会收不到上传的文件。

未完待续...

,

 

 

前言

本人在阿里云申请了个免费的空间,之前已经存放了一个项目,由于之前一直没时间,近期比较有空,所以想开发个个人博客,但是由于阿里云没有给我们权限来新建数据库,因此只能在原有的数据库另外“瓜分”一部分空间来做个人博客的数据库,我是在之前的JackSite.Entities实体项目上开发,因此只需要在定义一个DbContext即可。

PS:本次讨论的使用范围通过EF6(低版本是否支持多数据上下文我并不了解)用一个数据库构造多个DbContext

 

实现目标

原本默认Migration的文件是在Migrations,我现在希望已如下的形式来存放

Migrations项目中添加文件夹AMigration,BMigration文件来区分不同的DbContext迁移文件。

 

设置多数据上下文

首先我查找了下资料并未发现有类似Move-Migrations或者Update-Migrations的命令,因此我设想是是否同样是通过Enable-Migrations进行设置 
通过google 搜索关键字Single Database Multiple DbContext 搜到确实和我想象的一致都是通过此命令来设置多个数据库上下文的迁移文件路径 在抱着试试看的态度,进行了如下命令输入:

 

  1. Enable-Migrations -ContextTypeName:JackSite.Entities.Models.StudyTime.JackDbContext -MigrationsDirectory:Migrations\StudyTimeMigrations

ContextTypeNameDbContext的位置,即DbContext的命名空间加上DbContext的名称 
MigrationsDirectory:需要迁移到的目标文件夹 
PS:注意MigrationsDirectory:Migrations\StudyTimeMigrations中的'\'不要打错如输成'/'可能会引发一些问题 
同样我们对另一个数据上下文进行设置

 

  1. Enable-Migrations -ContextTypeName:JackSite.Entities.Models.Blog.BlogDbContext -MigrationsDirectory:Migrations\BlogMigrations

PS:这里两个DbContext用的是同样的连接串

 

更新数据脚本

最后通过运行Add-Migrations命令

这里需要注意:如果我们只有一个数据上下文,通过Add-Migrations命令会自动选择唯一的DbContext,但是如果有多个DbContext,我们必须指定我们需要对那个DbContext进行修改

 

  1. Add-Migration -ConfigurationTypeName JackSite.Entities.Migrations.BlogMigrations.Configuration InitBlogDb

这里通过-ConfigurationTypeName指定Configuration 后面接着是Configuration的路径,然后接着是我们取得名字InitBlogDb 
EF会找到指定的Configuration,并添加XXXX_InitBlogDb,结构如下图所示:

 
最后通过Update-Database进行更新

同样,我们这里需要指定需要更新哪个Configuration

 

  1. Update-Database JackSite.Entities.Migrations.BlogMigrations.Configuration

  2 使用EF和ASP.NET MVC的时候,如果视图中没有绑定KEY,需要用一个Html.HiddenFor(m=>m.key)来绑定主键,这样方便在后续post回发中获取对象的key。然后由于ASP.NET是短连接,回发的model是重新创建的detached状态,需要重新attach到DbContext才能正确更新。     3 DEVEXPRESS的文件上传控件不适合asp.net mvc的附件随表单上传,直接用input type=file上传更简单方便,另外上传文件的表单form要加enctype="multipart/form-data"属性,并且input type=file元素要有不同的name属性,否则服务端会收不到上传的文件。



点击数:121


一沙一世界,一花一天堂。君掌盛无边,刹那成永恒。