dapper sqlserver mysql_asp.net core使用Dapper操作Sqlserver/Oracle

无废话,还是先上git地址:https://gitee.com/jimmyTown_admin_admin/DapperInCoreDemo.git

结构如下:

20180715141810888137.png

1. 在framework时代,Dapper就因其小、轻但易用,高效而被很多程序员大量用与实际开发中。相对EF的宠大,我也更喜欢使用Dapper,今天正好有空,就顺手写了对应的Deamo(Demo分2部分,一部分是.net core console,一部分是asp.net core)。

开发环境:VS2017  .net core 2.1.3  IIS7.

2.  结构说明:

DapperInCoreLib中引用Dapper

20180715141811096153.png

Oracle.ManagedDataAccess.Core

20180715141811311981.png

引用OK后,根据Dapper的封装定义对应的通用接口

20180715141811550272.png

主要是针对dapper本身的实现作一些CURD的封装

1.2  接着就是针对接口的作对应的实现,这里会考虑兼容Sqlserver/oracle或其他DB(目前只是实现了这2种,但其实还支持mysql/sqlite等)

故实现的时候会根据对应的连接字符串及连接类型而使用对应的连接驱动

20180715141811750475.png

例如:其中查询的时候就会直接使用IDbConection作为连接,其他部分同理

20180715141812037595.png

1.3 DapperFactory

这里主要有2块

第一部分实现单例:所有连接的获取的入口点

第二部分:获取操作接口

20180715141812191898.png

1。4 简易仓储实现

接口部分(略,请直接看代码),实现部分:

20180715141812372569.png

接着看第2部分:对应的WebApi部分(主要1. 注入  2.Swagger, 3.log4net)

引入Swashbuckle.AspNetCore及log4net

2.1  配置IOC注入及swagger

20180715141812576678.png

2.2 配置log4net

20180715141812857939.png

20180715141812996616.png

当然日志也可以不使用Log4net而使用Microsoft.Extensions.Logging下的ILoggerFactory

20180715141813216351.png

运行看看效果(我这里将lauchSetting.json中的开始url变更为"launchUrl": "api/student"

20180715141813411671.png

默认显示所有学生信息,我们可以到swagger页面

20180715141813526910.png

这里就不一一尝试了,大家可以下载代码尝试

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值