很久没有写博客了,一些读者也经常问问一些问题,不过最近我确实也很忙,除了处理日常工作外,平常主要的时间也花在了继续研究微软的实体框架(EntityFramework)方面了。这个实体框架加入了很多特性(例如LINQ等),目前也已经应用的比较成熟了,之所以一直没有整理成一个符合自己 ...
很久没有写博客了,一些读者也经常问问一些问题,不过最近我确实也很忙,除了处理日常工作外,平常主要的时间也花在了继续研究微软的实体框架(EntityFramework)方面了。这个实体框架加入了很多特性(例如LINQ等),目前也已经应用的比较成熟了,之所以一直没有整理成一个符合自己开发模式的实体框架,是因为这个框架和原来我的基于EnterpriseLibrary的模式还是有很大的不同,不过实体框架推出来也很久了,目前也去到了EntityFramework6了,听说7也快出来了。
随着我自己参考阅读了大量的项目源码以及对实体框架各个技术点的学习深入,对其中很多的方面都有自己的一些见解和心得,希望通过这个系列,能够和读者一步步分析,一步步深入学习这个微软目前最为流行的.NET开发框架。本篇主要从基础开始一步步介绍基于泛型的仓储模式实体框架(The Entity Framework of Generic Repository Pattern ),希望大家耐心阅读。
1、实体框架的初步印象
最简单的实体框架,你可以在Winform或者Web项目里面添加一个【ADO.NET实体数据模型】项开始,一步步创建一个基于SqlServer的实体框架项目。最开始,我们可以不考虑什么设计模式,能够使用即可,因此我们可能创建一个比较简单的项目代码,这个有助于我们了解实体框架的一些基础工作原理。
为这个项目选定数据连接以及供测试使用的一两个表的对象,然后完成创建工作,这个【ADO.NET实体数据模型】创建完成后,我们可以看到项目里面添加了一个Model1.edmx的文件,并且同时生成了几个项目文件,其中包括了数据访问对象SqlserverContext和几个实体类(默认为表名称),我们也可以打开edmx的文件进行实体类属性的修改,如下所示。
默认生成后,我们就可以使用这个数据访问上下文对象SqlserverContext, 来进行相关的数据处理操作了,简单的测试代码如下所示。
private void GetIntData() { //创建数据访问对象 var context = new SqlserverContext(); //新建一个实体类并赋值 TB_Province info = new TB_Province(); info.ID = 100001; info.ProvinceName = "测试省份"; context.TB_Province.Add(info); context.SaveChanges(); //根据主键判断记录是否存在 TB_Province info2 = context.TB_Province.Find(info.ID); if (info2 != null) { Console.WriteLine("记录已存在!"); //如果存在对象,先删除 context.TB_Province.Remove(info2); context.SaveChanges(); //检查是否删除对象 info2 = context.TB_Province.Find(info.ID); if (info2 == null) { Console.WriteLine("记录已删除!"); } } //把记录全部获取并绑定到列表上。 var list = context.TB_Province.ToList(); this.dataget='_blank'>GridView1.DataSource = list; }
原标题:Entity Framework 实体框架的形成之旅
关键词:
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:
admin#shaoqun.com
(#换成@)。