在Entity Framework 4中映射现有实体类(POCO)

Entity Framework的全称是ADO.NET Entity Framework,是微软开发的基于ADO.NET的ORM(Object/Relational Mapping)框架。

Entity Framework的主要特点:

1. 支持多种数据库(Microsoft SQL Server, Oracle, and DB2);

2. 强劲的映射引擎,能很好地支持存储过程;

3. 提供Visual Studio集成工具,进行可视化操作;

4. 能够与ASP.NET, WPF, WCF, WCF Data Services进行很好的集成。

更多简介,请看:ADO.NET Entity Framework At-a-Glance

 

在博客园新版短消息功能开发中,我们准备用Entity Framework 4,我们首先面临这样的问题:

实体类与数据库都已经存在,而且实体类的类名与数据库中的表名,类的属性与表中对应的字段名称不同。也就是说我们不能使用通常的方法在VS2010中通过ADO.NET Entity Data Model(.edmx文件)生成实体类与ObjectContext。

注:这个实体类有个称呼叫POCO(Plain Old CLR Objects)。

我们解决方法是:在.edmx文件中手动配置映射关系。

下面是操作步骤:

1. 使用ADO.NET Entity Data Model,在VS2010创建一个.edmx文件,如下图:

2. 根据Entity Data Model Wizard进行操作,在选择数据库表的窗口中,注意在Model Namespace输入框中输入现有实体类的命名空间,如下图:

3. 点击Finish,生成相应的EntityType,如下图:

这里的EntityType是根据数据库中的表结构生成的,与实际的实体类是不一样的,表名与类名不一样,表的很多字段与类的属性不一样。

下面我们配置映射的关键地方:

4. 点击.edmx窗口点击空白处,在属性窗口中将Code Generation Strategy的属性设置为None(见下图),也就是不让VS2010自动生成实体类和对应的ObjectContext。

5. 继续在.edmx窗口,选择实体类,点击右键选择Show in Model Browser,见下图:

6. 进入Model Browser窗口,见下图:

上图中,上面是实体类(这里是VS2010自动生成的,与数据库表是一一对应的),下面是表结构。

修改映射就是在这里:在Entity Types中将类名改为实际的实体类名,将属性改为实际的属性,如下图:

修改之后,映射就配置好了,.edmx文件中实体类图中也随之自动更改,见下图:

7. .edmx文件实际就是一个xml文件,映射信息就存放在其中。在VS2010解决方案管理器中选择这个文件,右键Open With,选择用XML Editor打开,就可以看到.edmx文件的内容,如下图:

8. 再写个继承自ObjectContext的类(见下图),工作就完成了。

posted @   dudu  阅读(19543)  评论(20编辑  收藏  举报
编辑推荐:
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· spring官宣接入deepseek,真的太香了~
历史上的今天:
2007-01-27 公告
2005-01-27 [活动]2004年计算机图书评选
2005-01-27 SharePoint文档库存在问题
2005-01-27 [公告]SharePoint团队正式成立
2004-01-27 现在可以插入MSN表情了
2004-01-27 Microsoft Win32 to Microsoft .NET Framework API Map
点击右上角即可分享
微信分享提示