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

简单介绍一下三层架构, 三层架构从上到下分:表现层(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. C# 获取客户端信息 /asp.net/WebService/WebForm

    Request.Browser.MajorVersion.ToString();//获取客户端浏览器的(主)版本号Request.Browser.Version.ToString();   //获取客 ...

  2. Django Redis存储session会话

    通常redis都是用来保存session.短信验证码.图片验证码等数据. 在django上使用redis,先要安装一个包: pip install django-redis==4.8.0(我用的dja ...

  3. Ubuntu添加源列表

    1.首先备份源列表:sudo cp /etc/apt/sources.list /etc/apt/sources.list_backup 2.清空原来的/etc/apt/sources.list,添加 ...

  4. SQL Server数据库快照的工作方式

    SQL Server数据库快照的工作方式 翻译自:How Database Snapshots Work 最近有一个帖子<errorlog中的异常信息rolled forward 和rolled ...

  5. MYSQL 5.7 sqlmode 行为

    最近碰到了sql_mode 的一些问题,故进行了研究,根据实际情况研究其行为. sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ER ...

  6. 转:winform 安装包(很详细)

    winform安装项目.安装包的制作.部署 ① 1,解决方案—添加—新建项目—其他项目类型—安装和部署—安装项目,输入名称Setup,点“确定” 2,添加主输出:单击左侧“应用程序文件夹”,右侧右键— ...

  7. Flask 的馈赠

    我们在之前用过装饰器  但是在装饰很多函数的时候  那么这些函数的名字都是装饰器内部函数的名字了怎么办呢? django中有functools进行保留你的函数名字保存 flask也可以使用functo ...

  8. Apache下开启SSI配置,使html支持include包含

    有的时候,我们的页面有公共的导航栏navbar,公共的脚注footer,那么我们就想把这些公共部分独立成一个html文件,在要引用的地方像引用js,css一样,给包含进来. Apache下开启SSI配 ...

  9. 铁乐学Python_Day34_Socket模块2和黏包现象

    铁乐学Python_Day34_Socket模块2和黏包现象 套接字 套接字是计算机网络数据结构,它体现了C/S结构中"通信端点"的概念. 在任何类型的通信开始之前,网络应用程序必 ...

  10. 团队开发中,eclipse中安装jre

    团队合作中配置jre时,jre名称应该保持一致,否则不要提交.classpath文件 window-preferences     团队合作中,JRE name一定要一致!