引文

  hi,大家好,我是三合。不知各位有没有想过,如果能把数据库操作和http访问都统一封装成接口(interface)的形式,

然后接口对应的实现类由框架去自动生成,那么必然能大大降低工作量,因为不需要去写很多重复的代码了,还有一个好处是,都是提供接口,我们把原来数据库操作的部分,改成http访问,对于业务层来说,是无感的,因为接口和方法都没变。致力于降低上手net core的门槛,我开源了SummerBoot项目,下面让我们来看一下效果。

数据库表对应实体类,这些都是常规操作,略过

重头戏,如何写接口,以一个简单的购物功能为例子

数据库访问

订单详情仓储

订单仓储

http访问

控制器中进行构造函数注入

实际调用

        /// <summary>
/// 添加订单
/// </summary>
/// <param name="dto"></param>
/// <returns></returns>
[HttpPost("AddOrder")]
public async Task<IActionResult> AddOrder([FromBody]AddOrderDto dto)
{
if (dto?.ProductList==null) return BadRequest("参数不能为空"); Uow.BeginTransaction();
try
{
var orderHeader = new OrderHeader
{
CreateTime = DateTime.UtcNow,
CustomerNo = dto.CustomerNo,
State = 1,
OrderNo = Guid.NewGuid().ToString("N")
}; await OrderHeaderRepository.InsertAsync(orderHeader); var orderDetailList = new List<OrderDetail>();
//总消费金额
var totalAmount = 0m;
dto.ProductList.ForEach(it =>
{
var orderDetail = new OrderDetail
{
OrderHeaderId = orderHeader.Id,
ProductNo = it.ProductNo,
ProductName = it.ProductName,
Quantity = it.Quantity,
Price = it.Price
};
orderDetailList.Add(orderDetail); totalAmount += it.Quantity * it.Price;
}); await OrderDetailRepository.BatchInsertAsync(orderDetailList);
//更新用户消费金额
var success = await CustomerRepository.UpdateCustomerAmount(dto.CustomerNo, totalAmount); if (!success)
{
Uow.RollBack(); return BadRequest();
}
}
catch (Exception e)
{
Uow.RollBack();
} Uow.Commit(); return Ok();
} /// <summary>
/// 删库跑路
/// </summary>
/// <returns></returns>
[HttpGet("DeleteDatabase")]
public async Task DeleteDatabase()
{
await OrderHeaderRepository.DeleteAllOrder();
} /// <summary>
/// 根据会员编号取消订单
/// </summary>
/// <param name="customerNo"></param>
/// <returns></returns>
[HttpGet("CancelOrderByCustomerNo")]
public async Task<bool> CancelOrderByCustomerNo(string customerNo)
{
var count = await OrderHeaderRepository.CancelOrderByCustomerNoAsync(customerNo);
return count > 0;
} /// <summary>
/// 分页,根据会员编号获取消费详情
/// </summary>
/// <param name="customerNo"></param>
/// <returns></returns>
[HttpGet("QueryOrderDetailByCustomerNoByPage")]
public async Task<Page<OrderDetail>> QueryOrderDetailByCustomerNoByPage(int pageNumber,int pageSize, string customerNo)
{
var page=new Pageable(pageNumber,pageSize);
var result = await OrderDetailRepository.GetOrderDetailByCustomerNoByPageAsync(page,customerNo);
return result;
} /// <summary>
/// 根据会员编号获取消费详情
/// </summary>
/// <param name="customerNo"></param>
/// <returns></returns>
[HttpGet("QueryOrderDetailByCustomerNo")]
public async Task<List<OrderDetail>> QueryOrderDetailByCustomerNo(string customerNo)
{
var result= await OrderDetailRepository.GetOrderDetailByCustomerNoAsync(customerNo);
return result;
}

动态生成接口实现类的原理

  最开始写的时候,思路是,采用AOP思想,castle动态生成接口实现类,实现类里的方法都没有具体实现,然后在切面里对方法进行拦截并且模拟方法的实现,提供返回值,java中很多骚操作就是这么实现的,但是后来发现在.net

中这种实现方式有很大的弊端,因为.net有异步方法,而castle对于异步方法的支持是很弱的,不足以实现最开始的设想,于是,我换了一种思路,在数据库操作和http调用中,抛开动态实现类这个壳子,具体执行操作的类是恒定不变的,

那么利用emit技术动态路由到要执行的方法就行了。

写在最后

  如果这篇文章对你有所启发不妨点个赞吧。

  github地址:https://github.com/TripleView/SummerBoot,欢迎star!

  QQ群:799648362

  nuget包:SummerBoot

net core天马行空系列:降低net core门槛,数据库操作和http访问仅需写接口,实现类由框架动态生成的更多相关文章

  1. net core天马行空系列: 泛型仓储和声明式事物实现最优雅的crud操作

    系列目录 1.net core天马行空系列:原生DI+AOP实现spring boot注解式编程 哈哈哈哈,大家好,我就是那个高产似母猪的三合,长久以来,我一直在思考,如何才能实现高效而简洁的仓储模式 ...

  2. net core天马行空系列: 一个接口多个实现类,利用mixin技术通过自定义服务名,实现精准属性注入

    系列目录 1.net core天马行空系列:原生DI+AOP实现spring boot注解式编程 2.net core天马行空系列: 泛型仓储和声明式事物实现最优雅的crud操作 哈哈哈哈,大家好,我 ...

  3. net core天马行空系列:SummerBoot,将SpringBoot的先进理念与C#的简洁优雅合二为一

    系列目录 1.net core天马行空系列:原生DI+AOP实现spring boot注解式编程 2.net core天马行空系列: 泛型仓储和声明式事物实现最优雅的crud操作 3.net core ...

  4. net core天马行空系列:移植Feign,结合Polly,实现回退,熔断,重试,超时,做最好用的声明式http服务调用端

    系列目录 1.net core天马行空系列:原生DI+AOP实现spring boot注解式编程 2.net core天马行空系列: 泛型仓储和声明式事物实现最优雅的crud操作 3.net core ...

  5. MySQL 系列(二) 你不知道的数据库操作

    第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 本章内容: 查看\创建\使用\删除 数据库 用户管理及授权实战 局域网 ...

  6. net core天马行空系列:原生DI+AOP实现spring boot注解式编程

    写过spring boot之后,那种无处不在的注解让我非常喜欢,比如属性注入@autowire,配置值注入@value,声明式事物@Transactional等,都非常简洁优雅,那么我就在想,这些在n ...

  7. net core天马行空系列-微服务篇:全声明式http客户端feign快速接入微服务中心nacos

    1.前言 hi,大家好,我是三合,距离上一篇博客已经过去了整整两年,这两年里,博主通关了<人生>这个游戏里的两大关卡,买房和结婚.最近闲了下来,那么当然要继续写博客了,今天这篇博客的主要内 ...

  8. net core天马行空系列-可用于依赖注入的,数据库表和c#实体类互相转换的接口实现

    1.前言 hi,大家好,我是三合.作为一名程序猿,日常开发中,我们在接到需求以后,一般都会先构思一个模型,然后根据模型写实体类,写完实体类后在数据库里建表,接着进行增删改查, 也有第二种情况,就是有些 ...

  9. net core天马行空系列-各大数据库快速批量插入数据方法汇总

    1.前言 hi,大家好,我是三合.我是怎么想起写一篇关于数据库快速批量插入的博客的呢?事情起源于我们工作中的一个需求,简单来说,就是有一个定时任务,从数据库里获取大量数据,在应用层面经过处理后再把结果 ...

随机推荐

  1. FME中矢量裁剪

  2. coding++:使用 javascript 在html中获取url参数

    函数处理定义如下: < script type = "text/javascript" > function $G() { var Url = top.window.l ...

  3. Python python 函数参数:参数组合

    '''在Python中定义函数,可以用必选参数.默认参数.可变参数和关键字参数, 这4种参数都可以一起使用,或者只用其中某些 参数定义的顺序必须是:必选参数.默认参数.可变参数和关键字参数 ''' d ...

  4. Selenium Grid 的使用

    简介 Selenium Grid 是 selenium 的三大组件之一,允许用户同时在不同的机器和系统上测试不同的浏览器,可以分布式的来执行我们的自动化测试,也可以测试不同浏览器的兼容性. Selen ...

  5. js拖拽效果的实现及原理

    元素拖拽分成3个步骤:按下鼠标,移动鼠标,松开鼠标. 拖拽原理:按下拖拽元素后开始监听文档中鼠标移动事件,然后再监听鼠标松开事件:鼠标移动时,元素div要随着鼠标一起移动,需要计算元素div位移的距离 ...

  6. vulnhub~MyExpense

    最近有点忙,这几天的vulnhub断更了,今天试着做了一下myexpense,当然想要一帆风顺是不可能的,哪怕是有别人的steps 和walkthrough.所以就遇到的坑总结如下: 一般套路就是nm ...

  7. mysql清空表后id重1开始

    通过"truncate table 表名"方式重置清空id,让id从1开始自动递增,

  8. PTA数据结构与算法题目集(中文) 7-19

    PTA数据结构与算法题目集(中文)  7-19 7-19 求链式线性表的倒数第K项 (20 分)   给定一系列正整数,请设计一个尽可能高效的算法,查找倒数第K个位置上的数字. 输入格式: 输入首先给 ...

  9. Maven快照版本要这样用才真的香!

    Bug的身世之谜 今天又分享一个问题解决的故事.请看下图框起来的错误,明显就是找不到这个class嘛! 下面我们按照正常人的思路去排查这个问题,既然找不到class那就先看这个依赖的jar包有没有,如 ...

  10. 数据库服务概述,构建MYSQL服务器,数据库基本管理,mysql数据类型,表结构的调整

                                                            数据库的发展前引 MySQL的起源与发展过程 最为著名.应用最广泛的开源数据库软件 最早 ...