Entity Framework 实体框架的形成之旅

很久没有写博客了,一些读者也经常问问一些问题,不过最近我确实也很忙,除了处理日常工作外,平常主要的时间也花在了继续研究微软的实体框架(EntityFramework)方面了。这个实体框架加入了很多特性(例如LINQ等),目前也已经应用的比较成熟了,之所以一直没有整理成一个符合自己开发模式的实体框架,是因为这个框架和原来我的基于EnterpriseLibrary的模式还是有很大的不同,不过实体框架推出来也很久了,目前也去到了EntityFramework6了,听说7也快出来了。

随着我自己参考阅读了大量的项目源码以及对实体框架各个技术点的学习深入,对其中很多的方面都有自己的一些见解和心得,希望通过这个系列,能够和读者一步步分析,一步步深入学习这个微软目前最为流行的.NET开发框架。本篇主要从基础开始一步步介绍基于泛型的仓储模式实体框架(TheEntity Framework of Generic Repository Pattern ),希望大家耐心阅读。

1、实体框架的初步印象

最简单的实体框架,你可以在Winform或者Web项目里面添加一个【ADO.NET实体数据模型】项开始,一步步创建一个基于SqlServer的实体框架项目。最开始,我们可以不考虑什么设计模式,能够使用即可,因此我们可能创建一个比较简单的项目代码,这个有助于我们了解实体框架的一些基础工作原理。

为这个项目选定数据连接以及供测试使用的一两个表的对象,然后完成创建工作,这个【ADO.NET实体数据模型】创建完成后,我们可以看到项目里面添加了一个Model1.edmx的文件,并且同时生成了几个项目文件,其中包括了数据访问对象SqlserverContext和几个实体类(默认为表名称),我们也可以打开edmx的文件进行实体类属性的修改,如下所示。

默认生成后,我们就可以使用这个数据访问上下文对象SqlserverContext, 来进行相关的数据处理操作了,简单的测试代码如下所示。

private void GetIntData(){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();}}list = context.TB_Province.ToList();this.dataGridView1.DataSource = list;}

最后获得的界面效果就是能够顺利执行各种操作后把记录显示出来到列表上了。

2、实体框架的工作原理

1)数据访问上下文对象介绍

从上面的代码我们可以看到,数据访问上下文对象SqlserverContext已经可以直接和数据库交互了,能够实现表对象基本增删改查的操作功能了,那么这个类是如何的呢?为什么具有这个功能呢?

我们先看看它的代码,SqlserverContext的类代码如下所示(代码为自动生成的)。

SqlserverContext : DbContext{public SqlserverContext(): ){} OnModelCreating(DbModelBuilder modelBuilder){throw new UnintentionalCodeFirstException();}public virtual DbSet<TB_City> TB_City { get; set; }public virtual DbSet<TB_Province> TB_Province { get; set; }public virtual DbSet<TB_DictType> TB_DictType { get; set; }}

其中代码DbSet<TB_Province> TB_Province代表一个具体的数据访问对象,对表TB_Province的数据访问,其他的类似。我们查看.NET的内置对象DbSet的已经支持了一些常规的操作了。

而EMDX文件的本身是一个XML文件,它的内容如下所示。

实体框架本身通过XML映射的方式(ORM方式),封装了从数据库到实体类,以及实体类到数据库的交互过程,具体的过程我们可以参考下面的实体数据模型 (EDM)介绍。

2)实体数据模型 (EDM)介绍

坚硬的城市里没有柔软的爱情,生活不是林黛玉,

Entity Framework 实体框架的形成之旅

相关文章:

你感兴趣的文章:

标签云: