• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

C#的三层架构

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

最近做项目的时候,在数据访问层中 使用Ado.Net Entity Framework来创建当前的数据库对应的实体类和数据访问代码。如下图:

但是发现实体类和数据访问都在同一个DX.Data类中,如果其他的类,例如DX.BLL需要使用实体类的时候,必须引用DX.Data,这样就会造成访问数据的代码页给暴露出来了,为了避免这种情况,需要将实体类和数据访问分离出来,将实体类转移到DX.Model 层中(即实体层)。下面我们就将介绍一下如何利用T4模板来解决此问题.

1.双击 DX.CIC.edmx,然后 右键单击"Add Code Generation Item..",如下图:

 

2.在弹出的对话框中 选择 "ADO.NET Self-Tracking Entity Generator",然后在 Name文本框中 输入名称 如:DX.CIC.tt.创建成功后将会产生 2个TT文件和一个 App.config.其中App.config是配置数据库信息 。2个 TT文件,DX.CIC.tt 表示数据访问代码类,DX.CIC.Context.tt表示数据库对应的实体类 。

3.在DX.Data中剪贴DX.CIC.tt,然后将其复制到DX.Model层中,此时编译整个解决方案,将编译不通过。需要对这2个文件重新配置一下。

4.在DX.Model层中引用System.Rutime.Serialization ,双击DX.CIC.tt,然后在文件中找到string inputFile = @"DX.CIC.edmx";将其修改为string inputFile = @"../DX.Data/DX.CIC.edmx";

5.在DX.Data层中,引用DX.Model层,双击DX.CIC.Context.tt 在using System; using System.Collections.Generic; using System.ComponentModel; using System.Data.Common; using System.Data.EntityClient; using System.Data.Metadata.Edm; using System.Data.Objects.DataClasses; using System.Data.Objects; using System.Data; using System.Diagnostics; using System.Globalization; using System.Linq;

下面using System.Linq 添加 using DX.Model; 保存.然后编译解决方案。编译成功。

这样就把数据访问层和 实体层分离开来。整体结构如下:

 C#的三层架构 

最近做项目的时候,在数据访问层中 使用Ado.Net Entity Framework来创建当前的数据库对应的实体类和数据访问代码。如下图:

但是发现实体类和数据访问都在同一个DX.Data类中,如果其他的类,例如DX.BLL需要使用实体类的时候,必须引用DX.Data,这样就会造成访问数据的代码页给暴露出来了,为了避免这种情况,需要将实体类和数据访问分离出来,将实体类转移到DX.Model 层中(即实体层)。下面我们就将介绍一下如何利用T4模板来解决此问题.

1.双击 DX.CIC.edmx,然后 右键单击"Add Code Generation Item..",如下图:

 

2.在弹出的对话框中 选择 "ADO.NET Self-Tracking Entity Generator",然后在 Name文本框中 输入名称 如:DX.CIC.tt.创建成功后将会产生 2个TT文件和一个 App.config.其中App.config是配置数据库信息 。2个 TT文件,DX.CIC.tt 表示数据访问代码类,DX.CIC.Context.tt表示数据库对应的实体类 。

3.在DX.Data中剪贴DX.CIC.tt,然后将其复制到DX.Model层中,此时编译整个解决方案,将编译不通过。需要对这2个文件重新配置一下。

4.在DX.Model层中引用System.Rutime.Serialization ,双击DX.CIC.tt,然后在文件中找到string inputFile = @"DX.CIC.edmx";将其修改为string inputFile = @"../DX.Data/DX.CIC.edmx";

5.在DX.Data层中,引用DX.Model层,双击DX.CIC.Context.tt 在using System; using System.Collections.Generic; using System.ComponentModel; using System.Data.Common; using System.Data.EntityClient; using System.Data.Metadata.Edm; using System.Data.Objects.DataClasses; using System.Data.Objects; using System.Data; using System.Diagnostics; using System.Globalization; using System.Linq;

下面using System.Linq 添加 using DX.Model; 保存.然后编译解决方案。编译成功。

这样就把数据访问层和 实体层分离开来。整体结构如下:

 C#的三层架构 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
使用Delphi声明C++带函数的结构体实战good发布时间:2022-07-13
下一篇:
雅虎公司C#笔试题发布时间:2022-07-13
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap