第一次写博客,想了半天先从简单的三层架构开始吧,希望能帮助到你!

简单介绍一下三层架构, 三层架构从上到下分:表现层(UI),业务逻辑层(BLL),数据访问层(DAL)再加上数据模型(Model),用ef访问数据库,Model也就是与数据库表映射的实体。废话少说,上代码。

  • Model层

为方便说明,新建一个实体模型UserInfo,数据库表中应该对应一个UserInfo表,至于怎样建立表,有多种方式,用ef来建立表比较方便。具体怎样用ef访问数据库,后续会在其他文章中解释,敬请关注。

     public class UserInfo
{
public int Id { get; set; }
public string Name { get; set; }
public short Age { get; set; }
}
  • DAL层

首先设计通用的CRUD基接口IBaseDal,作为通用的数据库访问通道。

     public interface IBaseDal<T> where T : class,new()
{
void Add(T entity);
void Delete(T entity);
void Update(T entity);
IQueryable<T> GetEntities(Expression<Func<T, bool>> expression);
IQueryable<T> GetEntitiesByPage<TKey>(int pageSize, int pageIndex, bool isAsc, Expression<Func<T, TKey>> keySelector, Expression<Func<T, bool>> expression);
bool SaveChanges();
}

以UserInfo实体为例,继承IBaseDal接口

    public interface IUserInfoDal : IBaseDal<UserInfo>
{ }

接口设计完成,设计通用基类,这里存在变化点,本例用ef实现,如果以后通过其他实体框架或者直接通过ado.net访问数据库,只需要改动这个类。

    public class BaseDal<T> where T : class,new()
{
private DbContext dbContext = DbContextFactory.DbContext; public void Add(T entity)
{
dbContext.Set<T>().Add(entity);
} public void Delete(T entity)
{
dbContext.Entry(entity).State = EntityState.Deleted;
} public void Update(T entity)
{
dbContext.Entry(entity).State = EntityState.Modified;
} public IQueryable<T> GetEntities(Expression<Func<T, bool>> expression)
{
return dbContext.Set<T>().Where(expression);
} public IQueryable<T> GetEntitiesByPage<TKey>(int pageSize, int pageIndex, bool isAsc, Expression<Func<T, TKey>> keySelector, Expression<Func<T, bool>> expression)
{
if (isAsc) //升序
{
return dbContext.Set<T>().Where(expression).OrderBy(keySelector).Skip((pageIndex - ) * pageSize).Take(pageSize);
}
else //降序
{
return dbContext.Set<T>().Where(expression).OrderByDescending(keySelector).Skip((pageIndex - ) * pageSize).Take(pageSize);
}
} public bool SaveChanges()
{
return dbContext.SaveChanges() > ;
}
}
    public static class DbContextFactory
{
public static DbContext DbContext
{
get
{
DbContext dbContext = CallContext.GetData("DbContext") as DbContext;
if (dbContext == null)
{
dbContext = new ModelContainer();
CallContext.SetData("DbContext", dbContext);
}
return dbContext;
}
}
}

接下来实现具体的实体数据访问层,以UserInfoDal为例,其余类似。

    public class UserInfoDal : BaseDal<UserInfo>, IUserInfoDal
{ }
  • BLL层

首先像DAL层一样,定义通用接口。

    public interface IBaseService<T> where T : class,new()
{
void Add(T entity);
void Delete(T entity);
void Update(T entity);
IQueryable<T> GetEntities(Expression<Func<T, bool>> expression);
IQueryable<T> GetEntitiesByPage<TKey>(int pageSize, int pageIndex, bool isAsc, Expression<Func<T, TKey>> keySelector, Expression<Func<T, bool>> expression);
bool SaveChanges();
}

通用基类,注意通用基类不需要实现上面的接口

    public class BaseService<T> where T : class,new()
{
private BaseDal<T> baseDal = new BaseDal<T>(); public void Add(T entity)
{
baseDal.Add(entity);
} public void Delete(T entity)
{
baseDal.Delete(entity);
} public void Update(T entity)
{
baseDal.Update(entity);
} public IQueryable<T> GetEntities(Expression<Func<T, bool>> expression)
{
return baseDal.GetEntities(expression);
} public IQueryable<T> GetEntitiesByPage<TKey>(int pageSize, int pageIndex, bool isAsc, Expression<Func<T, TKey>> keySelector, Expression<Func<T, bool>> expression)
{
return baseDal.GetEntitiesByPage(pageSize, pageIndex, isAsc, keySelector, expression);
} public bool SaveChanges()
{
return baseDal.SaveChanges();
}
}

接下来是UserInfoService

    public class UserInfoService : BaseService<UserInfo>, IBaseService<UserInfo>
{ }

至此,所有底层代码完成,顶层的UI层调用不在赘述了,这里附上源码下载地址

链接:https://pan.baidu.com/s/1itW5XKBYB1onkQDfuwJvMw
提取码:ye0n

说明:源码中Model层中采用的ef的Model First方式创建数据库,下载以后不能直接运行,可以将Model程序集中的Model.edmx.sql在sqlserver创建数据库,以DataBase First方式重新创建Model程序集,可以正常运行。

三层架构搭建(asp.net mvc + ef)的更多相关文章

  1. 搭建三层架构(ASP.NET MVC+EF)

    昨天面试的时候最后做了一道上机题,竟然跪了,跪就跪在没有搭好框架,连接数据库总是程序报错. 回来之后亲自搭了一下框架,弄好后放到博客上.下图就是搭建好后,整个框架的结构就是这样,下面对框架中的文件进行 ...

  2. 转载——Asp.Net MVC+EF+三层架构的完整搭建过程

    转载http://www.cnblogs.com/zzqvq/p/5816091.html Asp.Net MVC+EF+三层架构的完整搭建过程 架构图: 使用的数据库: 一张公司的员工信息表,测试数 ...

  3. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(1)-框架搭建

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(1)-框架搭建 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) 前言:这篇博客开始我们便一步一步的来实现这 ...

  4. MVC三层架构搭建

    MVC三层架构搭建 项目主要是用三层来搭建项目,三层分为表现层,数据层和业务层.项目用了目前比较流行的IOC架构.目前流行的IoC 框架有AutoFac,Unity,Spring.NET等,项目中选用 ...

  5. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(16)-类库架构扩展以及DLL文件生成修改和用户的简单添加

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(16)-类库架构扩展以及DLL文件生成修改和用户的简单添加 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) ...

  6. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(14)-主框架搭建

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(14)-主框架搭建    ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框架搭建    (2 ...

  7. 搭建连接MySql的三层架构的ASP.NetCore2.0的WebApi

    里我们用三层架构搭建一个连接MySql的ASP.netCore模板的WebApi项目 首先添加WebApi项目(ASP.NetCore版本) 右键解决方案>新建项目> 选择Web>A ...

  8. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(3)-面向接口的编程

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(3)-面向接口的编程 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)  (1)框架搭建    (2):数据 ...

  9. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(23)-设置角色遗留问题和为权限设置角色以及EasyUI Tabs的使用

    ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框架搭建    (2):数据库访问层的设计Demo    (3):面向接口编程   (4 ):业务逻辑层的封装    ...

随机推荐

  1. Eclipse 下载、安装、取消自动更新、设置编码、关联Tomcat

    1.下载 (1)安装jdk 如果进行web开发,下载java se 版本的jdk即可,不需要像安装 java se 一样安装java ee(里面大多是接口和抽象类).关于java ee的依赖问题有两种 ...

  2. eclipse使用git命令行

    idea自带git命令,可以很方便的进行提交代码.eclipse怎么做呢,下面我简单操作一下: 第一步: 第二步: 第三步: 这样就调出来git提交的命令窗口了: 运行成功如下: 注意: git的安装 ...

  3. 事件驱动模型 IO多路复用 阻塞IO与非阻塞IO select epool

    一.事件驱动 1.要理解事件驱动和程序,就需要与非事件驱动的程序进行比较.实际上,现代的程序大多是事件驱动的,比如多线程的程序,肯定是事件驱动的.早期则存在许多非事件驱动的程序,这样的程序,在需要等待 ...

  4. UBUNTU16.04 连接不了cn.archive.ubuntu.com

    ubuntu系统更换源 更换源的方法非常简单:修改/etc/apt/sources.list文件即可 进入目录 /etc/apt cd /etc/apt修改sources.list文件 sudo vi ...

  5. 由delete导致的超时已过期问题

    1. 问题 开发人员反映应用程序中一条简单的delete语句执行报“超时已过期”错误.delete语句形式如下: delete * from table_1 where id=@value 2. 分析 ...

  6. webpack-易混淆部分的解释

    原文链接: https://medium.com/@rajaraodv/webpack-the-confusing-parts-58712f8fcad9 webpack的核心哲学 1. 任何皆模块 正 ...

  7. iOS设计模式 - 享元

    iOS设计模式 - 享元 原理图 说明 享元模式使用共享物件,用来尽可能减少内存使用量以及分享资讯给尽可能多的相似物件:它适合用于只是因重复而导致使用无法令人接受的大量内存的大量物件.通常物件中的部分 ...

  8. 《编程题》穷举法求N年后有多少头牛

    若一头小母牛,从出生起第四个年头开始每年生一头母牛,按这个规律,第N年时有多少头母牛? #include <iostream> int main(int argc, const char ...

  9. 初识HTML和WEB标准

    初识HTML和WEB标准 什么是 HTML? HTML 超文本标记语言的缩写(Hyper Text Markup Language) HTML 并不是编程语言,而是一种标记语言(markup lang ...

  10. SpringBoot部署流程

    一.  项目介绍 a)     本项目为SpringBoot项目 b)     使用内置Tomcat容器 一.  操作步骤 a)     配置pom.xml文件,确定打包方式 b)     更改项目返 ...