在.net core开发过程中,使用最多的就是注入方法。但是在.net core使用PetaPoco时,PetaPoco还不支持进行注入方式进行处理一些问题。

今天对PetaPoco进行了一些扩展,可以很方便的将PetaPoco进行注入操作,使用和EF很相似,但是更加简单

1、对PetaPoco.Compiled进行的一些扩展PetaPoco.Compiled.Extensions库

nuget:https://www.nuget.org/packages/PetaPoco.Compiled.Extensions/  欢迎使用

github:https://github.com/mzy666888/PetaPoco.Compiled.Extensions  欢迎star

具体扩展内容如下

1.1 创建PetaPocoDBContextOptions类

namespace PetaPoco.Compiled.Extensions
{
using Microsoft.Extensions.Options; public class PetaPocoDBContextOptions : IOptions<PetaPocoDBContextOptions>
{
/// <summary>The default configured TOptions instance</summary>
PetaPocoDBContextOptions IOptions<PetaPocoDBContextOptions>.Value => this; public string ConnectionString { get; set; }
public string ProviderName { get; set; }
} }

1.2 创建接口IPetaPocoDBContext

接口继承IDatabase

public interface IPetaPocoDBContext:IDatabase
{ }

1.3 创建类PetaPocoDBContext

类继承IPetaPocoDBContext

namespace PetaPoco.Compiled.Extensions
{
using Microsoft.Extensions.Options;
using PetaPoco; public abstract class PetaPocoDBContext:Database,IPetaPocoDBContext
{
/// <summary>
/// 构造函数
/// </summary>
/// <param name="optionsAccessor"></param>
protected PetaPocoDBContext(IOptions<PetaPocoDBContextOptions> optionsAccessor)
: base(optionsAccessor.Value.ConnectionString, optionsAccessor.Value.ProviderName)
{ }
}
}

1.4 添加对IServiceCollection的扩展

namespace PetaPoco.Compiled.Extensions
{
using Microsoft.Extensions.DependencyInjection; public static class PetaPocoDBContextServiceCollectionExtensions
{
public static IServiceCollection AddPetaPoco<T>(
this IServiceCollection services,
Action<PetaPocoDBContextOptions> setupAction)
where T : class ,IPetaPocoDBContext
{
if (null == services)
{
throw new ArgumentNullException(nameof(services));
} if (null == setupAction)
{
throw new ArgumentNullException(nameof(setupAction));
} services.AddOptions();
services.Configure(setupAction);
services.AddScoped<IPetaPocoDBContext, T>();
return services;
}
}
}

这样对PetaPoco的扩展已经完成。

2.在ASP.NET Core MVC中使用PetaPoco.Compiled.Extensions

首先使用nuget对PetaPoco.Compiled.Extensions的引用

使用命令:Install-Package PetaPoco.Compiled.Extensions -Version 0.0.1

添加一个继承PetaPocoDBContext的DBContext类

namespace PetaPoco.Compiled.Extensions.MvcTest.DBContexts
{
using Microsoft.Extensions.Options; public class MvcPetaPocoDBContext:PetaPocoDBContext
{
/// <summary>
/// 构造函数
/// </summary>
/// <param name="optionsAccessor"></param>
public MvcPetaPocoDBContext(IOptions<PetaPocoDBContextOptions> optionsAccessor)
: base(optionsAccessor)
{
}
}
}

添加好后,就可以在Startup中进行注入了,如下图所示

需要添加MySQL.Data的nuget引用

在appsettings.json文件中,数据库连接字符串配置如下:

"ConnectionStrings": {
"MySQL": {
"MvcMySQL": "server=127.0.0.1;port=3306;uid=root;pwd=123456;database=WireCloud;",
"provider": "MySql.Data.MySqlClient"
}
}

添加数据库表:Users(后续将使用EFCore进行CodeFirst进行处理)

添加对Users的操作接口和实现

namespace PetaPoco.Compiled.Extensions.MvcTest.Services
{
using PetaPoco.Compiled.Extensions.MvcTest.Models; public interface IUserService
{
IList<User> GetAll();
} public class UserService : IUserService
{
private PetaPocoDBContext _context; public UserService(PetaPocoDBContext context)
{
_context = context;
}
public IList<User> GetAll()
{
return _context.Fetch<User>();
}
}
}

在HomeController中添加一个Action

namespace PetaPoco.Compiled.Extensions.MvcTest.Controllers
{
using PetaPoco.Compiled.Extensions.MvcTest.Services; public class HomeController : Controller
{
private IUserService _userService; public HomeController(IUserService userService)
{
_userService = userService;
}
public IActionResult Index()
{
return View();
} public IActionResult Privacy()
{
return View();
} [ResponseCache(Duration = , Location = ResponseCacheLocation.None, NoStore = true)]
public IActionResult Error()
{
return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });
} public IActionResult Users()
{
return View(_userService.GetAll());
}
}
}

View实现

@model System.Collections.Generic.IList<PetaPoco.Compiled.Extensions.MvcTest.Models.User>

<div>
@foreach(var user in Model)
{
<div>@user.Uid</div>
<div>@user.UserName</div>
}
</div>

运行并访问:http://localhost:52769/Home/Users

下一步实现EF Core 的CodeFirst功能,然后就能快速使用PetaPoco+EF Core相结合进行快速码代码了

EF  Core的代码也可以自己去实现

参考文章

在.net core 中PetaPoco结合EntityFrameworkCore使用codefirst方法进行开发的更多相关文章

  1. 在ASP.NET Core中构建路由的5种方法

    原文链接 :https://stormpath.com/blog/routing-in-asp-net-core 在ASP.NET Core中构建路由的5种方法 原文链接 :https://storm ...

  2. C#调用接口注意要点 socket,模拟服务器、客户端通信 在ASP.NET Core中构建路由的5种方法

    C#调用接口注意要点   在用C#调用接口的时候,遇到需要通过调用登录接口才能调用其他的接口,因为在其他的接口需要在登录的状态下保存Cookie值才能有权限调用, 所以首先需要通过调用登录接口来保存c ...

  3. ASP.Net Core中处理异常的几种方法

    本文将介绍在ASP.Net Core中处理异常的几种方法 1使用开发人员异常页面(The developer exception page) 2配置HTTP错误代码页 Configuring stat ...

  4. ASP.NET Core中app.UseDeveloperExceptionPage和app.UseExceptionHandler方法有什么用

    在新建一个ASP.NET Core项目后,在项目Startup类的Configure方法中默认会添加两个方法的调用,app.UseDeveloperExceptionPage和app.UseExcep ...

  5. .NET Core 中读取appsettings.json配置文件的方法

    appsettings.json配置文件结构如下: { "WeChatPay": { "WeChatApp_ID": "wx9999998999&qu ...

  6. 关于vue项目中axios跨域的解决方法(开发环境)

    1.在config文件中修改index.js proxyTable: { "/api":{ target: 'https://www.baidu.com/muc/',//你需要跨域 ...

  7. ASP.NET Core 中文文档 第三章 原理(6)全球化与本地化

    原文:Globalization and localization 作者:Rick Anderson.Damien Bowden.Bart Calixto.Nadeem Afana 翻译:谢炀(Kil ...

  8. Swift中字符串转化为Class的方法

    Swift中字符串转化为Class的方法 在开发中有时候会根据字符串进行对应类的转化,这样我们就可以动态根据服务器返回的字段,动态的加载类,比如优酷,微博等APP会在节假日等动态的TabBar.这样可 ...

  9. .Net Core 中使用PetaPoco ,T4生成模版

    话不多说,直接上源码. 1.引用NuGet 2.添加T4 <#@ template debug="true" hostspecific="false" l ...

随机推荐

  1. 找出数组中最大值and索引

    找出数组中的最大值和和最大值的索引位置..... 第一中方法: /** * 找出数组中最大值和最大值的索引 * @param args */ public static void main(Strin ...

  2. JAVA的环境变量配置

    开发JAVA程序需要先准备开发环境,安装好操作系统后首先需要去下载JDK并安装. JDk(Java Development Kit )是Java开发工具包,如果您要开发基于Java的应用首先需要下载并 ...

  3. 探索微信小程序之路

    记录一下每日的知识点,时不时温习一下. 视图与渲染对于页面中的数据,以json的方式存放在js文件的data中 判断的使用: <view wx:if='{{true}}'> 为真时显示 & ...

  4. shell脚本学习-循环

    跟着RUNOOB网站的教程学习的笔记 for循环 与其他编程语言类似,shell支持for循环. for循环一般格式为: for var in item1 item2 ... itemN do com ...

  5. 网络编程 —— UPD

    UDP协议(数据报协议:SOCK_DGRAM) udp是无链接的,先启动哪一端都不会报错 udp协议的特点: 传输数据不可靠,发送完后没有确认就删除 传送内容可为空 对于查寻速度快 支持的是一对多的模 ...

  6. Python学习过程中各个难点---数据类型篇

    ---恢复内容开始--- 当时在学习python的基本数据类型时,对于可变与不可变类型不是了解的很透彻,这篇是回过头来自己的一些理解. 可变的数据类型有列表,不可变的数据类型有字符串,数字和元组   ...

  7. 重构SP5中声明自定义扩展类为API调用

    展的自定义类方法想要被前端异步调用必须在方法中 1.首先类必须继承自 AppService 类 2.方法必须指定特性 [ActionDescription("名称","编 ...

  8. navibar记录

    @import (reference) "kmc-common.less"; .kmc{ font-family: PingFangSC-Reguxlar; font-weight ...

  9. Python小练习之判断一个日期是一年的第几天

    python练手遇到的一个问题写了个统一公式,不用麻烦的分各种类,如果有人测试出错误请评论通知. #分单双月 def dayNum(month,day,isLeap): if month % 2 != ...

  10. Azure Active Directory document ---reading notes

    微软利用本地活动目录 Windows Server Active Directory 进行身份认证管理方面具有丰富的经验,现在这一优势已延伸基于云平台的Azure Active Directory.可 ...