在上一篇文章中,我们已经搭建了整个芒果后台管理系统整个工程架构,并集成了AutoMapper,日志组件等,接下来我们将使用Entity Framework完善系统的持久化存储部分。这篇EF的构造,我将以一种快速集成的方式实现,并提供超多的Linq公共方法供业务使用。

Nuget引入EF

在XiaoMo.Repository工程里,右键工程使用Nuget引入EntityFramework ,这里我使用最新的6.4版本

在XiaoMo.Service的Web.config里,添加Sql Server连接字符串(AppSetting内)

	<add key="conStr" value="Server=10.60.215.202;Database=mango_sys;Persist Security Info=True;User ID=sa;Password=**" />

创建表

创建表以及Entity

对应Entity

[Table("Orders")]

public class OrderInfoEntity
{
    public int Id { get; set; }
    public DateTime OptTime { get; set; }
    public string Address { get; set; }
    public string Uuid { get; set; }
    public string AcceptUser { get; set; }
    public string TelephoneNumber { get; set; }
    public string ProductName { get; set; }
    public int Number { get; set; }
    public double Price { get; set; }
    public double Sum { get; set; }
    public string PackCompany { get; set; }
    public string PackNumber { get; set; }
    public string Status { get; set; }
    public string ExpressNumber { get; set; }

}

EF关键配置

创建数据库交互上下文DatabaseContext.cs,初始化时指定连接。这里因为我们先用数据库表,所以我们使用Database.SetInitializer(null); 使用空策略初始化EF 。添加DBSet,用于操作表。

public class DatebaseContext : DbContext
{
    static string ConnectionString = "";
    static DatebaseContext()
    {
        Database.SetInitializer<DatebaseContext>(null);
    }

    public DatebaseContext(string connStr)
      : base(connStr)
    {
    }

    public DatebaseContext()
        : base(GetConnectionString())
    {

    }

    private static string GetConnectionString()
    {
        if (string.IsNullOrEmpty(ConnectionString))
        {
            ConnectionString = ConfigurationManager.AppSettings["conStr"].ToString();
        }
        return ConnectionString;
    }

    public virtual DbSet<OrderInfoEntity> Records { get; set; }
    public virtual DbSet<UsersEntity> User { get; set; }
}

添加数据交互接口,这里只列出几个关键接口方法

	public interface IRepository{}

	public interface IRepository<TEntity> : IRepository where TEntity : class

//methods

    T Query<T>(Func<IQueryable<TEntity>, T> queryMethod);
	TEntity FirstOrDefault(Expression<Func<TEntity, bool>> predicate);
	TEntity Load<TPrimaryKey>(TPrimaryKey id);
	bool Exist(Expression<Func<TEntity, bool>> predicte);
	TEntity Insert(TEntity entity);
	TEntity Update(TEntity entity);

创建RepositoryManager.cs,封装DatabaseContext,并实现CRUD

	public class RepositoryManager : IDisposable

创建RepositoryEntityBase.cs,作为所有Dao层的公共基类,以供继承映射数据库实体。

    public class RepositoryEntityBase<TEntity> : IRepository<TEntity> where TEntity : class

创建OrderDao

	public class OrdersDao : RepositoryEntityBase<OrderInfoEntity>

这两个文件内容过多,我就不粘贴到这了。

业务访问持久化逻辑

列举几个使用集成好的EF框架交互的例子

1.查询当前用户是否为代理

	public bool IsAgent(string username)
	{
		using (var repMgr = new RepositoryManager())
		{
			return repMgr.Exist<UsersEntity>(u => u.UserName == username && u.Role == 1);

		}
	}

2.判断用户名密码是否正确

 public string SearchUser(string username,string pwd)
    {
        using (var repMgr = new RepositoryManager())
        {
            var queryuser = repMgr.FirstOrDefault<UsersEntity>(u => u.UserName == username && u.Password == pwd);
		}
	}

3.分页查询订单

public QueryResponse Query(QueryRequest request)
    {
        using (var repMgr = new RepositoryManager())
        {
            var response = new QueryResponse();
            var query = repMgr.Query<OrderInfoEntity>();
							int count = query.Count();
							 var results = query.OrderByDescending(s => s.OptTime).Skip((request.CurrentPage - 1) * request.PageSize).Take(request.PageSize);

            var entities = results.ToList();
            response.TotalCount = count;
            response.Result = entities.ConvertAll(Mapper.Map<OrderInfoEntity, OrderInfo>);
            return response;
			}
		}

4.创建订单

	public OrderInfo CreateOrder(OrderInfo order)
    {
        using (var repMgr = new RepositoryManager())
        {
                var entity = Mapper.Map<OrderInfo, OrderInfoEntity>(order);
                repMgr.Insert(entity);
                repMgr.Commit();
                order.Id = entity.Id;
		}
	}

整个数据库的查询和操作相当简单。这里您可能会问,如果有一些复杂的Sql语句,要怎么写,这里我们在RepositoryManager.cs里提供执行Sql语句的方法,只需要把sql与参数传递进来即可

 public int ExecuteSqlCommand(string sql, params object[] args)
    {
        return Context.Database.ExecuteSqlCommand(sql, args);
    }

如果有新的业务接入,那我们只需要在DatebaseContext中加入新的DBSet,创建对应Entity与表,其他不需要任何改动,整个EF的接入是超级便捷的。

结语

以上为大家实现系统集成EF的关键配置代码,由于篇幅较长,部分源码我并未粘贴全,大家如果感兴趣,可以私信小墨公众号,联系,下一节我们将继续芒果系统的快速搭建,IOC集成Castle。整个系列我将面向入门级新手,以实战干货角度为大家陆续呈现,之后将为大家呈现以.Net Core MVC姿势构建系列,希望大家支持。如需源码,请关注小墨公众号私信,并获取更多小墨精彩分享!

感谢阅读!

本文由博客群发一文多发等运营工具平台 OpenWrite 发布

ASP.NET MVC5实现芒果分销后台管理系统(二):Code First快速集成EntityFramework的更多相关文章

  1. ASP.NET MVC5实现芒果分销后台管理系统(一):系统结构设计,集成AutoMapper,Log4net

    在构思完系统思维脑图后,小墨回到家中,便摩拳擦掌开始了开发工作.要想迅速完成系统开发,前期系统设计和准备尤其重要,因为小墨做过太多大大小小的业务系统,准备工作也是十分顺利. 系统结构 整个系统工程结构 ...

  2. 使用ASP.NET MVC 5快速实现芒果分销后台管理系统(前言)

    ### 前言 在前一篇文章中,我提到最近要陆续为大家写一些.Net实战技术文章.从今天起,我将围绕一个入门级现实的芒果分销管理系统案例,使用ASP.NET MVC 5,从前端到后端,一步一步为大家呈现 ...

  3. 最新版 INSPINIA IN+ - WebApp Admin Theme v2.7.1,包含asp.net MVC5示例代码,做管理系统最佳的选择。

    下载地址:http://download.csdn.net/download/wulang1988/10039402 最新版 INSPINIA IN+ - WebApp Admin Theme v2. ...

  4. asp.net EF+MVC+Bootstrap 通用后台管理系统

    需要源码,请加QQ:858-048-581 开发环境: VS2012或以上 数据库: SQL Server 2008R2或以上   基于EF+MVC+Bootstrap构建通用后台管理系统,集成轻量级 ...

  5. 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](二)

    前言: 在本系列第一篇<一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](一)>中,我为大家介绍了搭建空白解决方案以 ...

  6. 【共享单车】—— React后台管理系统开发手记:Redux集成开发

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  7. 基于VUE实现的新闻后台管理系统-二

    基础环境及最后的开发效果已完成说明,接下来就开始配置. ¶npm初始化 新建项目文件夹VueDemo,在其内执行如下脚本 npm init -y 安装vue-cli构建包 yarn add vue-c ...

  8. Vue+element搭建后台管理系统-二、安装插件

    我们继续上一章的内容,上一章讲到我们已经能将项目成功跑起来了,那么我们接下来把项目必用的东西完善一下. 一.安装elementUI 终于到了我们的男二了,继续在VSCode中新建一个终端,然后通过这个 ...

  9. 一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](三)

    前言 上一篇<一步一步创建ASP.NET MVC5程序[Repository+Autofac+Automapper+SqlSugar](二)>我们通过如下操作: 创建实体及工具类 创建Re ...

随机推荐

  1. 合并cookie,提取json数据

    发送的第3个请求需要前两个请求的cookie,需要对cookie进行合并 发送的请求数据来自于json数据中的某个键值. 这里是删除所有的对话主题目录,每一个目录有一个id,发起删除对话主题目录的请求 ...

  2. c中结构体边界对齐

    原则1.普通数据成员对齐规则:第一个数据成员放在offset为0的地方,以后每个数据成员存储的起始位置要从该成员大小的整数倍开始(比如int在32位机为4字节,则要从4的整数倍地址开始存储). 原则2 ...

  3. Pandas提取单元格的值

    如提取第1行,第2列的值: df.iloc[[0],[1]] 则会返回一个df,即有字段名和行号. 如果用values属性取值: df.iloc[[0],[1]].values 返回的值会是列表,而且 ...

  4. Android开发常见错误

    1.出现 “Unable to resolve target 'android-9'”,解决办法: 一般移植别人工程会出现此错误. 右键项目文件--->properties--->andr ...

  5. sed 分组替换

    将文件以help开头的句子前加# [root@localhost]# cat a.txthelp b helphelp1helphelp2help c help[root@localhost]# se ...

  6. 利用机器学习检测HTTP恶意外连流量

    本文通过使用机器学习算法来检测HTTP的恶意外连流量,算法通过学习恶意样本间的相似性将各个恶意家族的恶意流量聚类为不同的模板.并可以通过模板发现未知的恶意流量.实验显示算法有较好的检测率和泛化能力. ...

  7. 渗透之——MSF提权

    在WEB渗透中当我们拿到webshell了,我们可以试试用MSF(metasploit)来进行提权,在MSF里meterpreter很强大的! 我们先用msfvenom生成一个EXE的木马后门. ms ...

  8. MySql5.7.28下载、安装、登陆详解

    进入MySql官网下载,页面如下 根据自己需求,选择适合自己的进行下载 然后解压安装包到自己的喜欢的路径 配置环境变量 添加环境系统变量 MYSQL_HOME:D:\Program Files\mys ...

  9. Golang 使用Protocol Buffer 案例

    目录 1. 前言 2. Protobuf 简介 2.1 Protobuf 优点 2.2 Protobuf 缺点 2.3 Protobuf Golang 安装使用 3. Protobuf 通讯案例 3. ...

  10. 利用ajax 引入静态页公共的头部与底部

    利用ajax引入公共的头部与底部或者多个页面需要用到的重复的组件,对于新入门的前端来说是很实用的方法,自己也是新手菜鸟一枚,折腾了好久,实现的方法有很多种,这是我个人觉得比较简单方便的 首先得把公用的 ...