这是上周就写好的文章,是在公司浩哥的建议下写的,本来是部门里面分享求创新用的,这里贴出来分享给大家。
最近在对MVC的学习过程中,接触到了Code First这种新的设计模式,感觉很新颖,并且也体验到了这种方式所带来的便利。这里将我的一些理解分享出来。
需要了解的概念
POCO
POCO(Plain Old CLR Object)的概念是从java的POJO借用而来,而两者的含义是一致的,不同的仅仅是使用的语言不一样。所以POCO的解释就是“Plain Old C# Object”。POJO的内在含义是指那些没有从任何类继承、也没有实现任何接口,更没有被其它框架侵入的对象。
PO
PO是指持久对象(persistant object持久对象)。持久对象实际上必须对应数据库中的entity,所以和POJO有所区别。比如说POJO是由new创建,由GC回收。但是持久对象是 insert数据库创建,由数据库delete删除的。基本上持久对象 生命周期和数据库密切相关。另外持久对象往往只能存在一个数据库 Connection之中,Connnection关闭以后,持久对象就不存在了,而POJO只要不被GC回收,总是存在的。
ORM
ORM(Object/Relational Mapping) 对象关系映射,主要是把数据库中的关系数据映射称为程序中的对象
NHibernate
NHibernate是一个面向.NET环境的对象/关系数据库映射工具。对象/关系数据库映射(object/relational mapping,ORM)这个术语表示一种技术,用来把对象模型表示的对象映射到基于SQL的关系模型数据结构中去。所以NHibernate与Entity Framework是很相近的。
Entity Framework
Entity Framework的全称是ADO.NET Entity Framework,是微软开发的基于ADO.NET的ORM(Object/Relational Mapping)框架。
其架构图如下:
在接手一个新项目时我们所熟知及习惯使用的设计方式,是在分析需求后开始创建数据库中的表,一旦表确定后变动不会太大或者几乎不再去更改表的结构,后面的模型编写及业务逻辑的编写都在这个基础上进行。这种方式称为Database First。
而在2011四月发布的Entity Framework 4中存在三种工作方式,他们分别为:Code First, Model First和Database First。其中本文要讨论的Code First就是新增的一种方式。
Code First
为了支持以设计为中心的开发流程,EF4 还更多地支持以代码为中心 (code-centric) ,我们称为代码优先的开发,代码优先的开发支持更加优美的开发流程,它允许你:
在不使用设计器或者定义一个 XML 映射文件的情况下进行开发。
·允许编写简单的模型对象POCO (plain old classes),而不需要基类。
·通过"约定优于配置",使得数据库持久层不需要任何的配置
·也可以覆盖"约定优于配置",通过流畅的 API 来完全定制持层的映射。
Code First是基于Entity Framework的新的开发模式,原先只有Database First和Model First两种。Code First顾名思义,就是先用C#/VB.NET的类定义好你的领域模型,然后用这些类映射到现有的数据库或者产生新的数据库结构。Code First同样支持通过Data Annotations或fluent API进行定制化配置。
其他两种设计方式
Database First是最老也是应用得最广泛的一种设计方式。如上文提到过的那样,Database First这种方式的设计高度依赖于数据库中表的结构,根据表及表间的关系来创建模型。如果后期需求有所变更或者功能有很大变化的话,需要涉及到更改数据库所付出的代价将会很大,因为之前编写好的代码将不再适用于新的表,我们必需重构以更改代码中的逻辑以适应更改之后的表。
Model Firstj是创建ADO.NET实体对象以及它们之间的关系,然后再指定到数据库的映射。这个实体对象即为Model。
在MVC中使用CodeFirst
这里我将用一个非常简单的例子来演示一下Code First在MVC中的使用,主要还是展示Code First 具体是怎么工作的。
Note:你可能需要单独安装Entity Framework 4.1
ADO.NET Entity Framework 4.1 安装文件下载地址:http://www.microsoft.com/download/en/details.aspx?displaylang=en&id=8363
下面我们开始这个例子。既然是Code First,就是以代码为中心进行设计,所以我们并不关心具体的数据库构造到底是怎么样的。我们从分析需求开始,即我们要实现的功能。这里我仅仅是要实现一个展示博客列表的页面,这里我们不关注CRUD的实现,因为这些都可以在MVC里自动生成。这里我们将看到,整个过程我们没有写sql语句,也没有用sql server management studio 在数据库里进行表的设计,但我们运行程序时,这些需要的表就已经自动创建好了,并且我们在页面进行CRUD操作时,也是与数据库里面的数据是完全同步的。
打开VS2010新建一个MVC3项目,注意环境要设为.Net Framework 4。这里我将项目命名为MvcBlog。
选择空的模板,View engine我们用ASPX。
因为Code First需要EntityFramework支持,项目创建好后在引用里面系统已经自动为我们引用了EntityFramework程序集,如果没有需要手动引用进来。
(为了展示完整的目录层结构,在图片上我把中间很多引用去掉换以省略号代替,所以你看到这张图片时不要感到奇怪,我的VS不是特别定制版的)
我们首先在Model中创建一个博客类来保存一篇博客的基本信息,它包含一个博客标识BlogId, 标题Title还有创建日期CreateDate。
在Model文件夹上右击选择Add->Class。
在Name中输入Blog再点击Add。
其中的代码如下:
1 namespace MvcBlog.Models2 3 {4 5 public class Blog6 7 {8 9 public int BlogId { get; set; } 10 11 public string Title { get; set; } 12 13 14 15 public DateTime CreateDate { get; set; } 16 17 } 18 19 }
同样的方法我们再新建一个类,命名为BlogEntities.cs,这个类跟Blog类的功能是不同的,我们将在代码里将它定义为从DBContex继承,这样这个BlogEntities上下文类将扮演着与数据库沟通的重要角色,在这里面可以定义需要的表,项目运行后这些表将自动在数据库创建。这里,我们用刚才定义好的Blog来定义一个Dbset,代码如下:
1 public class BlogEntities:DbContext 2 3 { 4 5 public DbSet<Blog> Blogs { get; set; } 6 7 }
(注意:这里需要在文件顶部添加using System.Data.Entity引用语句才能使用DbContext及DbSet)
上面我们把模型准备好了,现在定义Controller。但在进行这一步前,我们需要Ctrl+Shift+B编译一下程序,以便系统知道我们之前定义好的Blog类和BlogEntities类。右击Controllers文件夹选择Add->Controller打开添加Controller对话框,将其命名为HomeController(MVC的Controller,当然你也可以随便命名,只不过在打开网页时需要手动输入路径),此刻数据库还没有被创建,并且呆会自动创建后里面也是空的没有数据,我们需要向里面添加一些数据,所以这里模板我们选择带有CRUD(增删除改查)功能的,再将下面的模型类选为Blog,上下文类选为BlogEntities,系统会自动实现CRUD操作,不用我们手动编写。
(注意:之前必需编译一下,才能在这一步的下拉菜单里找到我们已经定义好的类)
单击Add之后,生成的代码大概是这样:
+ View Code
视图已经自动添加在了Views文件夹下,到此我们的程序已经能够工作了,虽然我们似乎什么都没做。在运行前我们可以打开Sql server management studio (或者在VS里用服务器管理器连接到你本地的数据库)查看一下以确定数据库里还没有我们程序里需要的Blog表。然后我们Ctrl+F5运行网站。
页面显示出了我们在Blog中定义的Title字段和CreateDate字段,但由于还没有数据来进行显示,所以只有标题。
这个时候,我们断开数据库再重新连接,就会发现EF创建了一个程序命名空间为名称的数据库MvcBlog.Models.BlogEntities,里面包含我们用Dbset定义的Blogs表。表中的列也正好与我们在Blog类中定义的字段相对应。
仔细观察你会发现,它自动将BlogId定义为了主键,这是EF的convention在起作用,如果我们没有显示地指定数据库的连接字符串等配置信息,这些值将会遵从EF里的约定进行取值,比如这里的数据库名 MvcBlog.Models.BlogEntities。
这样的名称当然不是我们想要的,而且,如果我们本地安装了多个数据库实例的话,我们也希望指定项目将数据创建在我们想要的实例当中。要覆盖默认的约定,我们只需在Web.config(注意:不是Views文件夹下的Web.config)里添加一下对数据库的配置信息,代码如下:
<connectionStrings><add name="BlogEntities"connectionString="server=(local)\sqlexpress;database=MvcBlog;integrated security=true;"providerName="System.Data.SqlClient"/></connectionStrings>
注意上面的name应和Models中的定义的上下文类名称相同,这样才能使EF正常工作。server换成你本机数据库实例的名字。现在我们可以看到在先前那个数据库上方它生成了我们重新命名的数据库。
重新运行程序,我们在页面中点击Create New来添加几条数据。
添加完数据后我们再返回去看数据库中的变化。
如图,数据库中已经保存了我们在页面上添加的数据。
到这里大家已经看到了Code First 设计方式的大概过程。现在我们来回顾一下,之前所做的操作,将会更加明白这一过程是怎样进行的,特别是代码优先是如何做到在没有数据库支持的情况下先建立数据模型,然后再对数据库进行操作的。
首先我们在Models中创建了所需要的数据模型Blog类,里面包含的字段将映射到以后数据库表中的相应列。
接下来同样是在Models文件夹中,我们定义了一个最关键的BlogEntities上下文类,它继承自System.Data.Entity下的DbContext,它将我们的数据模型映射到数据库中,将代码中的数据持久化。
最后,在页面上进行添加数据时,页面将表单数据通过Blog类型传回Controller里面相应的方法,这里是处理Post回传的Create Action,它接收传回来的数据,通过调用db.SaveChanges()进行了数据的保存。这里db是BlogEntities上下文类的一个实例。通过BlogEntities上下文类,我们进行的RUD操作将反应到数据库中,完成了从代码到数据库的更新过程。
Data Annotations
接着上面的例子,试想,一篇博客一般还包含有分类信息,比如日志,随笔等。现在我们就去添加这样一个类,保存博客的分类信息,相应地,我们还应更新一下我们的博客类,让它包含一个分类属性,这样我们就可以指定一篇博客的所属分类了。
这里将看到如何通过Code First创建表间的外键关系约束,以及定义表中列的其他信息,比如显示的信息,
我们在Models文件夹中继续添加一个名为Category的类,它包含一个分类标识属性CategoryId, 一个分类名属性CategoryName。代码如下:
1 namespace MvcBlog.Models2 3 {4 5 public class Category6 7 {8 9 public int CategoryId { get; set; } 10 11 public string CategoryName { get; set; } 12 13 } 14 15 }
更新Blog类:
1 namespace MvcBlog.Models2 3 {4 5 public class Blog6 7 {8 9 public int BlogId { get; set; } 10 11 public string Title { get; set; } 12 13 public DateTime CreateDate { get; set; } 14 15 public int CategoryId { get; set; } 16 17 } 18 19 }
我们向其中添加了一个CategoryId属性,下面设置它为引用自Category中CategoryId的外键。
这里有两个方法Data Annotation 和 Fluent API用于实现这种到数据库的映射,这里只讨论Data Annotation。
由于CategoryId将会成为Blog到Category的导航属性,所以,除了要在Blog中添加CategoryId外,还需要添加一个类型为Category的属性,这样,在Blog中才会有一个来自Category中CategoryId的声明。
1 public class Blog2 3 {4 5 public int BlogId { get; set; }6 7 public string Title { get; set; }8 9 public DateTime CreateDate { get; set; } 10 11 public int CategoryId { get; set; } 12 13 public Category Category { get; set; } 14 15 }
在使用Data Annotation添加外键属性前需要添加System.ComponentModel.DataAnnotations命名空间到Blog类。然后我们就可以在CategoryId上面添加一个外键属性了。更改后的代码如下 :
public class Blog{public int BlogId { get; set; }public string Title { get; set; }public DateTime CreateDate { get; set; }[ForeignKey("CategoryId")]public int CategoryId { get; set; }public Category Category { get; set; }}
同时更新我们的BlogEntities对象:
1 public class BlogEntities:DbContext 2 3 { 4 5 public DbSet<Blog> Blogs { get; set; } 6 7 public Category Categories { get; set; } 8 9 }
这时当我们运行程序时,会报错,如图:
因为之前运行程序时已经创建了数据库了,而现在我们在对模型进行更改后,它无法完全将更改之后的模型映射到之前的数据库,所以会出错。从错误提示中已经给出了解决办法。要么手动删除之前创建好的数据库,要么使用DropCreateDatabaseIfModelChanges 的一个实例来对数据库进行初始化。需要注意的一点是,在商业开发中,第二种方法要小心使用,因为它会把之前的数据库自动删掉重新创建,而如果你之前保存有大量信息在里面的话将无法挽回。
这里我们不想每次在修改模型之后都手动去删除,所以用第二种方法将十分简便,只需到Global.asax文件的Application_Start()方法里面添加如下一行即可。
1 protected void Application_Start()2 3 {4 5 Database.SetInitializer(new DropCreateDatabaseIfModelChanges<BlogEntities>());6 7 AreaRegistration.RegisterAllAreas();8 9 10 11 RegisterGlobalFilters(GlobalFilters.Filters); 12 13 RegisterRoutes(RouteTable.Routes); 14 15 }
这样,模型改变之后,它会删除掉原来的数据库重新创建。
我们再次运行程序,然后再去数据库看,第二张表Category已经添加进去了,并且在Blog表里面,也出现了一个CategoryId外键,正如我们所想要的那样。
需要注意的地方
一个就是性能问题,使用edm designer从数据库来生成的ObjectContext,它会把很多东西存在CSDL,MSL,SSDL文件里,比如一些mapping信息,当页面load时需要先从EDM文件里来load这些metadata,而使用Code-first是从Assembly里load数据,这样应该会节省不少时间。但另一方面,EF自动生成的CONTEXT实体类会附带很多冗余信息,使得文件相对臃肿,在读取实体类中的信息时会在搜索上耗费不必需的时间。关于性能问题具体可阅读一下参考中的第一篇文章。
另外就是现在Code First应用得不是很多,就现在学习中碰到的例子来看,大部分都是Database First方式的。由于这是伴随微软新一代的EF4.1推出的设计方式,必定有其优越性,所以以后的项目中还是可以尝试用这种方式来进行设计。
后记
我也是初学者,研究得不是很深刻,借鉴了许多别人的经验与分享,再加上自己的创新理解,肯定有不恬当的地方,权当加深自己的理解,与大家共同学习。
可以参考的一些文章
1.WCF和Entity framework 发现的性能问题
http://www.cnblogs.com/GaryChen/archive/2010/02/06/1664912.html
2.Entity Framework 4中的Code-First, Model-First和Database-First模式
http://www.cnblogs.com/n-pei/archive/2010/08/12/1797751.html
3.Code-First Development with Entity Framework 4
http://weblogs.asp.net/scottgu/archive/2010/07/16/code-first-development-with-entity-framework-4.aspx
4.ADO.NET Entity Framework
http://en.wikipedia.org/wiki/ADO.NET_Entity_Framework
5.A Code First Example using Entity Framework 4
http://chris.widdowson.id.au/?p=746#
6. Entity Framework At-a-Glance
http://msdn.microsoft.com/en-us/data/aa937709
7. Nadege Deroussen在codeproject的三篇文章
Entity Framework Code First: Let's Try It
http://www.codeproject.com/Articles/318010/Entity-Framework-Code-First-Let-s-Try-It
EF Code First: Add a Foreign Key relationship
http://www.codeproject.com/Articles/319366/EF-Code-First-Add-a-Foreign-Key-relationship
EF Data Annotations and Code Fluent
http://www.codeproject.com/Articles/368164/EF-Data-Annotations-and-Code-Fluent
CC BY-NC-SA 署名-非商业性使用-相同方式共享
分类: MVC
标签: Code First, Data Annotations, Entity Framework
好文要顶 关注我 收藏该文
刘哇勇
关注 - 11
粉丝 - 2723
推荐博客
+加关注
« 上一篇: 如何制作好一个提交按扭---我是个爱折腾的人
» 下一篇: 关于jQuery UI 使用心得及技巧
posted @ 2012-09-20 18:58 刘哇勇 阅读(50711) 评论(49) 编辑 收藏
评论列表
#1楼 2012-09-20 20:43 玉菜园
收藏
支持(0) 反对(0)
#2楼 2012-09-20 21:24 niky
讲的很基础同时也很到位!园子里相关的Entity Framework文章也挺丰富的!!!
支持(0) 反对(0)
#3楼 2012-09-20 22:49 zhangzhigang
写的灰常好
支持(0) 反对(0)
#4楼 2012-09-20 23:49 LiangCheng
写的很好,我刚刚聊了了EF但还不够深入,楼主收藏了
支持(0) 反对(0)
#5楼 2012-09-21 07:28 Kencery
学习了,谢谢楼主!
支持(0) 反对(0)
#6楼 2012-09-21 09:03 Y2zz
楼主辛苦了
支持(0) 反对(0)
#7楼 2012-09-21 09:05 骑马找驴
不错!基础通俗,顶
支持(0) 反对(0)
#8楼 2012-09-21 10:37 励箭
通俗易懂,顶
支持(0) 反对(0)
#9楼 2012-09-21 12:28 幻天芒
这是一篇好文呀,通俗易懂。
支持(0) 反对(0)
#10楼 2012-12-04 16:07 nickycookie
写的很清楚,EF还可以用Nuget下载,我也经常写一些工作中碰到问题后总结性的文章,楼主可以看下。
namespace MvcBlog.Models
{
public class Blog
{
public int BlogId { get; set; }
public string Title { get; set; }
public DateTime CreateDate { get; set; }
[ForeignKey("CategoryId")]
public int CategoryId { get; set; }
//这里是不是漏了public Category Category { get; set; }
}
}
不过说真的,我始终觉得再放一个CategoryId很怪,还是不太喜欢用EF,无论哪种模式
支持(0) 反对(0)
#11楼 2012-12-20 16:53 wuanju . com
最近想用,可看了感觉不如Nhibernate
支持(0) 反对(0)
#12楼 2013-01-19 18:20 风云
不错,正准备把自动建表的功能移植到ELinq中,呵呵
支持(0) 反对(0)
#13楼 2013-02-20 10:39 saiko
写的灰常好
支持(0) 反对(0)
#14楼 [楼主] 2013-05-13 22:54 刘哇勇@ nickycookie
引用写的很清楚,EF还可以用Nuget下载,我也经常写一些工作中碰到问题后总结性的文章,楼主可以看下。namespace MvcBlog.Models
{
public class Blog
{
public int BlogId { get; set; }
public string Title { get; set; }
public DateTime CreateDate { get; set; }
[ForeignKey("CategoryId")]
...
哎玛,还真的是少了句代码~
支持(0) 反对(0)
#15楼 2013-05-23 11:01 魔女小溪
之前看过entityframework,但是,始终都不明白什么意思,到现在还不不懂,呵呵,楼主写的确实非常详细,顶,灭哈哈哈
支持(0) 反对(0)
#16楼 2013-05-27 11:07 kiddy-star
首先,肯定文章写得很好,通俗易懂。个人的收获是Code First方式在数据表变更的时候很麻烦,实际又退化到Database First,不可能为了修改一个字段就去删除整个数据库,不过可能Code First有利有弊的考虑吧,只是在设计的时候用。
支持(0) 反对(0)
#17楼 2013-05-29 22:42 最佳损友。
study 慢慢看
支持(0) 反对(0)
#18楼 2014-04-29 10:21 魔女小溪
Lz,为啥我生成controller后,EntityState,这个报错,说上下文不存在
支持(0) 反对(0)
#19楼 2014-04-30 10:57 魔女小溪
LZ,你回我一下呀?为啥我总是出现这样的错误,不能够创建成功数据库,报错:在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider: SQL Network Interfaces, error: 26 - 定位指定的服务器/实例时出错)
支持(0) 反对(0)
#20楼 2014-04-30 11:23 魔女小溪
已经解决了创建数据库不成功这个问题了,但是,这个问题没有解决,楼主,你在木有呀,为啥我生成controller后,EntityState,这个报错,说上下文不存在
支持(0) 反对(0)
#21楼 2014-04-30 14:54 魔女小溪
LZ,还有个问题呀,我加一张相关联的表,不是你上面说的那种错误,而是出现另外一种错误,“The navigation property 'ClassId' is not a declared property on type 'SightPoint'. Verify that it has not been explicitly excluded from the model and that it is a valid navigation property.” 咋回事呀?你怎么不来逛园子呀!
支持(3) 反对(0)
#22楼 [楼主] 2014-05-02 08:41 刘哇勇
已解决~,勤奋的孩子@魔女小溪
支持(0) 反对(0)
#23楼 2014-05-04 10:30 魔女小溪
楼主,对于那个生成EntityState那个,我用mvc3,确实没错,这个问题是解决了,但是,还有一个问题没解决,就是那个添加关联表的时候,添加不成功,出错:
导航属性“ClassId”不是类型“SightPoint”的已声明属性。请验证该属性未从模型中显式排除并且是有效的导航属性。
global文件中我已经加了
Database.SetInitializer(new DropCreateDatabaseIfModelChanges<TourEntities>());,还是报这样的错误
支持(0) 反对(0)
#24楼 2014-06-03 11:32 hnxiangjiansheng
好文章
支持(0) 反对(0)
#25楼 2014-06-07 09:48 随风吹
楼主,我在按着你这个走的时候也遇到21楼的问题
The navigation property 'ClassId' is not a declared property on type 'SightPoint'. Verify that it has not been explicitly excluded from the model and that it is a valid navigation property
google了一下,貌似是依赖出现了问题,但是还是改不对,还请楼主赐教!谢谢了
支持(0) 反对(0)
#26楼 2014-06-07 09:50 随风吹@ 魔女小溪
引用LZ,还有个问题呀,我加一张相关联的表,不是你上面说的那种错误,而是出现另外一种错误,“The navigation property 'ClassId' is not a declared property on type 'SightPoint'. Verify that it has not been explicitly excluded from the model and that it is a valid navigation property.” 咋回事呀?你怎么不来逛园子呀!
请问你这个解决了吗?还请赐教,说明一下什么原因
支持(0) 反对(0)
#27楼 2014-06-07 10:05 随风吹额,google后改了
1 2 3 4 5 6 7 8 9 10 |
|
可以成功运行,但是后部原因还是有点迷糊
支持(1) 反对(0)
#28楼 2014-07-03 13:41 魔女小溪
@ 随风吹
还是不行呀?你另外一个类是怎么写的呢?
支持(0) 反对(0)
#29楼 2014-08-04 22:16 KennyZhao
写的不错,刚刚开始学习
支持(0) 反对(0)
#30楼 2014-09-14 20:59 学易不易
文中生成外键的方式有误,正确添加外键的方法可以参考下面这篇文章:
http://www.cnblogs.com/jes_shaw/archive/2013/03/06/2946061.html
支持(0) 反对(0)
#31楼 2014-10-16 15:50 郭卫东
收获很多,写的很不错
支持(0) 反对(0)
#32楼 2014-12-05 14:00 学亮
DBFirst真的不好吗?
支持(0) 反对(0)
#33楼 2015-01-28 23:52 郑志成
楼主,辛苦了,我收藏了哦
支持(0) 反对(0)
#34楼 2015-01-30 10:57 端木非
楼主 你写ForeignKey的时候 多了一个Id,害我报错:找不到元数据 希望楼主有空改改 不然很多人都会浪费很多时间!!!
[ForeignKey( "Category" )]
public int CategoryId { get; set; }
public Category Category { get; set; }
支持(0) 反对(0)
#35楼 2015-03-25 16:12 津沅
楼主 我按照你的 试着做了一下,在添加控制器的时候提示这个是什么原因,能否给解释一下。
支持(0) 反对(0)
#36楼 2015-04-05 13:09 清水圆柏
写的很详细,向您学习了。
支持(0) 反对(0)
#37楼 2015-05-18 16:31 0风随我动0
楼主,辛苦了,我收藏了哦
支持(0) 反对(0)
#38楼 2015-06-08 13:00 —阿辉
不错,大牛
支持(0) 反对(0)
#39楼 2015-06-11 16:38 AcherBoy、Chenjw
楼主、求改一下、依旧有问题
支持(0) 反对(0)
#40楼 2015-06-11 16:39 AcherBoy、Chenjw
INSERT 语句与 FOREIGN KEY 约束"FK_dbo.Blogs_dbo.Categories_CategoryId"冲突。该冲突发生于数据库"MvcBlog.Models.BlogEntities",表"dbo.Categories", column 'CategoryId'。
语句已终止。
说明: 执行当前 Web 请求期间,出现未经处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。
异常详细信息: System.Data.SqlClient.SqlException: INSERT 语句与 FOREIGN KEY 约束"FK_dbo.Blogs_dbo.Categories_CategoryId"冲突。该冲突发生于数据库"MvcBlog.Models.BlogEntities",表"dbo.Categories", column 'CategoryId'。
语句已终止。
支持(0) 反对(0)
#41楼 2015-06-25 11:57 小小中
学习了
支持(0) 反对(0)
#42楼 2015-07-13 09:57 thhhhhhea
请问为什么创建blogentity的时候,blog是dbset,而category就只是category了?
支持(0) 反对(0)
#43楼 2015-10-08 15:40 寝室长
34楼正解,重新编译后可解决35楼的问题
支持(0) 反对(0)
#44楼 2015-10-26 11:25 fren
感谢楼主分享
支持(0) 反对(0)
#45楼 2015-12-22 09:51 kiaser
楼主你那个MvcBlog.Models.BlogEntities的数据库生成的时候,webconfig的connectionString是怎么写的
支持(0) 反对(0)
#46楼 2016-07-08 11:04 2604529
mark
支持(0) 反对(0)
#47楼 2016-08-26 18:05 cnfanhua
那么问题来了,如果不使用DropCreateDatabaseIfModelChanges ,model中新增个属性 怎么办
支持(0) 反对(0)
#48楼 2017-05-09 22:48 Leelom
不错,必须操作到数据的时候才会触发生成表,比如“登录”、“显示”,不管是增删改查,任意一个操作“▲之后”才会生成表,否则不会生成。折腾半天。
支持(0) 反对(0)
#49楼 2019-03-13 17:02 学会乐观
@ AcherBoy、Chenjw
我和你遇到同样的问题