今天,我们谈一下如何用Entity Framework构建一个三层架构。即包括DAL层,BLL层和MODEL层。我们先看一下目录结构,如下图:

目录中,我们有Web层,AVON.DMS.Model是实体层,AVON.DMS.DAL是数据访问层,AVON.DMS.BLL是业务逻辑层.

下面,我们来看看怎么把三层分出来。

首先,我们先新建项目文件,并创建Web层。如下图:

新建AVON.DMS.Model 类库,AVON.DMS.DAL 类库,AVON.DMS.BLL 类库:

此类库主要引入数据库表。因为我用的是Oracle数据库,所以,你还得安装.NET访问Oracle的ODAC组件。

下载地址:http://www.oracle.com/technetwork/topics/dotnet/utilsoft-086879.html

安装完成之后,我们来在AVON.DMS.Model新增一个ADO.NET 实体数据模型,如下图:

点击 Add, 下一步:

下一步:

选择数据库并输入账号和密码:

测试连接:

下一步:

下一步:

点击 "Finish"之后,会自动生成Entity Framework框架的文件,如下图,我们看一下目录结构:

如图:箭头1是数据库层访问代码,箭头2是自动生成的实体类。

下一步,我们要把箭头1的代码层移到AVON.DMS.DAL层,如下图:

但是,保存之后,DMSModel.Context.cs里面并没有生成代码。先别急,我们修改一下DMSModel.Context.tt文件中DMSModel.edmx的路径,如下:

再引用EntityFramework.dll,AVON.DMS.Model和System.Data.Entity。编译成功之后,基本完成了Model层和DAL层的分离。

另外,需要把AVON.DMS.Model层中App.config的连接字符串拷贝到Web层。

 <add name="Entities" connectionString="metadata=res:***********" providerName="System.Data.EntityClient" />

下面,我们来编写基本的CRUD(增删查改)代码:(备注:由于作者使用的Oracle数据库表没有设置主键,所以要对DMSModel.edmx文件进行修改,可以查看另一篇文章Oracle + Entity Framework 更新没有设置主键的表)

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using AVON.DMS.Model; namespace AVON.DMS.DAL
{
public class RepDAL
{
Entities DMSDAL = new Entities();
/// <summary>
/// 添加会员
/// </summary>
/// <param name="rep">会员实体</param>
/// <returns></returns>
public bool AddtoRep(REP rep)
{
try
{
DMSDAL.REP.Add(rep);
DMSDAL.SaveChanges();
}
catch (Exception)
{
return false;
}
return true;
} /// <summary>
/// 根据会员编号删除会员
/// </summary>
/// <param name="repNo">会员编号</param>
/// <returns></returns>
public bool DeleteRep(string repNo)
{
try
{
REP delRep = DMSDAL.REP.First<AVON.DMS.Model.REP>(o => o.NO == repNo);
DMSDAL.REP.Remove(delRep);
DMSDAL.SaveChanges();
}
catch (Exception)
{
return false;
}
return true;
} /// <summary>
/// 根据会员编号返回会员实体
/// </summary>
/// <param name="repNo">会员编号</param>
/// <returns></returns>
public REP GetFromRep(string repNo)
{
try
{
return DMSDAL.REP.SingleOrDefault<AVON.DMS.Model.REP>(t => t.NO == repNo);
}
catch (Exception)
{
return null;
}
} /// <summary>
/// 更新实体
/// </summary>
/// <param name="rep">实体</param>
/// <returns></returns>
public bool UpdateRep(REP rep)
{
try
{
REP upRep = DMSDAL.REP.First<AVON.DMS.Model.REP>(o => o.NO == rep.NO);
upRep.ADDRESS1 = rep.ADDRESS1;
upRep.BIRTHDAY = rep.BIRTHDAY;
upRep.DELIVER = rep.DELIVER;
upRep.MAIL_NO = rep.MAIL_NO;
DMSDAL.SaveChanges();
}
catch (Exception)
{
return false;
}
return true;
} }
}

以上是在AVON.DMS.DAL中添加的代码,可以作为数据库层的代码。而业务逻辑代码可以编写在AVON.DMS.BLL层。

源代码可以在这里下载:源码

Entity Framework 是微软基于ADO.NET的ORM框架,Entity Framework的主要特点:
1. 支持多种数据库(Microsoft SQL Server, Oracle, and DB2);
2. 强劲的映射引擎,能很好地支持存储过程;
3. 提供Visual Studio集成工具,进行可视化操作;
4. 能够与ASP.NET, WPF, WCF, WCF Data Services进行很好的集成。

以上是一篇简单的入门介绍,希望能对您有所帮助,O(∩_∩)O哈哈~

Entity Framework 之三层架构的更多相关文章

  1. 基于EF+WCF的通用三层架构及解析

    分享基于EF+WCF的通用三层架构及解析 本项目结合EF 4.3及WCF实现了经典三层架构,各层面向接口,WCF实现SOA,Repository封装调用,在此基础上实现了WCFContext,动态服务 ...

  2. Entity Framework 数据并发访问错误原因分析与系统架构优化

    博客地址 http://blog.csdn.net/foxdave 本文主要记录近两天针对项目发生的数据访问问题的分析研究过程与系统架构优化,我喜欢说通俗的白话,高手轻拍 1. 发现问题 系统新模块上 ...

  3. ORM,Entity Framework介绍以及其所包含的基础架构介绍

    一:entity framework 6.0 ORM (实体关系模型) O: Domain Object 领域模型 R: Relational Database 关系型数据库 M: Mapping 映 ...

  4. Entity Framework 与 面向对象

    说要分享,我了个*,写了一半放草稿箱了两个星期都快发霉了,趁着周末写完发出来吧. 文章分为五部分: 基础.类讲述的是用到的一些EF与面向对象的基础: 业务是讲怎么划分设计业务: 设计模式和工作模式讲述 ...

  5. ADO.NET Entity Framework

    ADO.NET Entity Framework 是微软以 ADO.NET 为基础所发展出来的对象关系对应 (O/R Mapping) 解决方案, 早期被称为 ObjectSpace,现已经包含在 V ...

  6. csharp: NHibernate and Entity Framework (EF) (object-relational mapper)

    代码生成器: 1. http://www.codesmithtools.com/ 2.https://sourceforge.net/projects/mygeneration/ 3. http:// ...

  7. MVC项目实践,在三层架构下实现SportsStore-01,EF Code First建模、DAL层等

    SportsStore是<精通ASP.NET MVC3框架(第三版)>中演示的MVC项目,在该项目中涵盖了MVC的众多方面,包括:使用DI容器.URL优化.导航.分页.购物车.订单.产品管 ...

  8. Entity FrameWork 与 NHibernate

      1 Nhibernate 展示了NHibernate在数据库和用程序之间提供了一个持久层. 应用程序自己提供ADO.NET连接,并且自行管理事务.NHibernate体系结构如图1-51所示.它体 ...

  9. Entity Framework学习笔记(二)----CRUD(1)

    请注明转载地址:http://www.cnblogs.com/arhat 这篇文章老魏和大家分享一下Entity Framework的CRUD操作,在这之前呢,老魏先说一下老魏对EF的一个整体的认识, ...

随机推荐

  1. ZOJ 3633 Alice's present 倍增 区间查询最大值

    Alice's present Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/vi ...

  2. delphi 如何知道 Treeview,Listview 当前最上面显示的节点

    如何知道 Treeview,的节点是根节点       procedure TForm1.TreeView1ContextPopup(Sender: TObject; MousePos: TPoint ...

  3. delphi 设置超链接

     的属性 的事件 的方法 //1设置链接类型//2获取样式 链接和提示信息 //title是提示信息//HTTPS https://<a href="https://www.baidu ...

  4. material-singleinputform

    https://github.com/HeinrichReimer/material-singleinputform https://play.google.com/store/apps/detail ...

  5. CopyU!v2 已经收录到腾讯软件管家!

    腾讯软件管家已经正式收录了CopyU!,这样大家又多了一个安全快速下载软件的好途径!腾讯渠道的CopyU!更新将会保持与官方同步,现有下载CopyU!软件的渠道中,官方保证同步的主要有: 1.非凡软件 ...

  6. Java元组类型之javatuples

    转载:Java元组类型之javatuples 关于方法的返回值,经常需要返回2个值或多个值的一个序列,比如数据表的一条记录,文件的一行内容等.除了使用数组Array.集合(List.Set.Map)这 ...

  7. day05 Java基础

    1.数组初始化:为数组开辟内存空间,并为每个数组元素赋予值.数组初始化方式: 方式一:动态初始化:初始化时只指定数组长度,由系统为数组分配初始值. 格式:数组类型[] 数组名称=new 数组类型[数组 ...

  8. 关于dispatchTouchEvent, onInterceptTouchEvent, onTouchEvent的分发机制浅析

    虽说这个问题不是很难...动动手就能看出答案...但是似乎不太容易理解...几次尝试把这个问题说明白....但是好像感觉说不明白....(顿时想起了那句话----说不明白就是自己还不明白! 我怎么可能 ...

  9. maven系列之一maven安装和与IDE集成

    第一部分:maven的基本信息和安装,配置  maven是一个项目构建和管理的工具,提供了帮助管理 构建.文档.报告.依赖.scms.发布.分发的方法.可以方便的编译代码.进行依赖管理.管理二进制库等 ...

  10. 由c#的值类型与引用类型说开去

    之前一直被灌输,C#分值类型和引用类型,在程序运行时,它们分别存在栈(Stack) 和堆(Heap)上.这也是面试经典问题了,但其实其中存在很大的误解.比如某个实例对象中有一个Int型成员.当这个实例 ...