无废话,仍是先上git地址:https://gitee.com/jimmyTown_admin_admin/DapperInCoreDemo.gitmysql
结构以下:git
1. 在framework时代,Dapper就因其小、轻但易用,高效而被不少程序员大量用与实际开发中。相对EF的宠大,我也更喜欢使用Dapper,今天正好有空,就顺手写了对应的Deamo(Demo分2部分,一部分是.net core console,一部分是asp.net core)。程序员
开发环境:VS2017 .net core 2.1.3 IIS7.sql
2. 结构说明:json
DapperInCoreLib中引用Dapperapi
Oracle.ManagedDataAccess.Coreoracle
引用OK后,根据Dapper的封装定义对应的通用接口app
主要是针对dapper自己的实现做一些CURD的封装asp.net
1.2 接着就是针对接口的做对应的实现,这里会考虑兼容Sqlserver/oracle或其余DB(目前只是实现了这2种,但其实还支持mysql/sqlite等)url
故实现的时候会根据对应的链接字符串及链接类型而使用对应的链接驱动
例如:其中查询的时候就会直接使用IDbConection做为链接,其余部分同理
1.3 DapperFactory
这里主要有2块
第一部分实现单例:全部链接的获取的入口点
第二部分:获取操做接口
1。4 简易仓储实现
接口部分(略,请直接看代码),实现部分:
接着看第2部分:对应的WebApi部分(主要1. 注入 2.Swagger, 3.log4net)
引入Swashbuckle.AspNetCore及log4net
2.1 配置IOC注入及swagger
2.2 配置log4net
固然日志也能够不使用Log4net而使用Microsoft.Extensions.Logging下的ILoggerFactory
运行看看效果(我这里将lauchSetting.json中的开始url变动为"launchUrl": "api/student"
默认显示全部学生信息,咱们能够到swagger页面
这里就不一一尝试了,你们能够下载代码尝试