NetCore PetaPoco 事务处理分享

PetaPoco是一个轻量级的.NET和Mono数据库访问库,它以单个C#文件的形式存在,便于集成到任何项目中。PetaPoco的主要特点包括无依赖性、快速的性能和对简单事务的支持。它适用于严格的没有装饰的Poco类以及几乎全部加了特性的Poco类,并提供了多种数据库操作方法,如插入、删除、更新和查询。此外,PetaPoco还支持分页和参数化查询,以及简单的SQL事务处理。

示例代码处理了业务上的数量归档的更新操作

cs 复制代码
public async Task<bool> UpdateTransactionOrderAsync(long orderId,int usedCount)
{
    await CreateDAO().BeginTransactionAsync();
    try
    {
        string sql = string.Format("update requestlog set IsSaveToOrder =1 WHERE  1=1 and IsSaveToOrder=0 and OrderId={0}", orderId);
        int succCount1 = await CreateDAO().ExecuteAsync(sql);

        string sql2 = string.Format("update order set UsedCount ={0} WHERE id = {1}", usedCount, orderId);
        int succCount2 = await CreateDAO().ExecuteAsync(sql2);

        CreateDAO().CompleteTransaction();

        if (succCount1 >= 1 && succCount2 >= 1)
        {
            return true;
        }
        return false;
    }
    catch (Exception ex)
    {
        throw;
    }
}

CreateDAO() 是 BaseRepository 里面的PetaPocoDatabase实例

cs 复制代码
/// <summary>
/// 默认PetaPocoDatabase实例
/// </summary>
/// <returns></returns>
protected virtual IDatabase CreateDAO()
{
    return DbContext;
}
相关推荐
csdn_aspnet3 小时前
C# 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)
开发语言·算法·c#
武藤一雄7 小时前
C# 设计模式大全(第一弹|7种)
microsoft·设计模式·微软·c#·.net·.netcore
格林威8 小时前
Baumer相机锂电池极片裁切毛刺检测:防止内部短路的 5 个核心方法,附 OpenCV+Halcon 实战代码!
开发语言·人工智能·数码相机·opencv·计算机视觉·c#·视觉检测
向上的车轮9 小时前
熟悉C#如何转TypeScript——SDK与包引用
开发语言·typescript·c#
滴滴答答哒10 小时前
.netcore集成CAP事件总线,消息队列
.netcore
CSharp精选营10 小时前
Dispose 不释放?C# 资源泄漏的 3 种隐蔽场景排查
c#·资源泄漏
unicrom_深圳市由你创科技11 小时前
LabVIEW和C#在工业控制中的应用差异是什么?
fpga开发·c#·labview
唐青枫13 小时前
C#.NET Consul + Steeltoe 深入解析:服务注册发现、健康检查与微服务接入
c#·.net
DowneyJoy13 小时前
【Unity3D补充知识点】常用数据结构分析-集合(List<T>)
数据结构·unity·c#·list
格林威13 小时前
Baumer相机铝型材表面划伤长度测量:实现损伤量化评估的 5 个关键技术,附 OpenCV+Halcon 实战代码!
开发语言·人工智能·数码相机·opencv·计算机视觉·c#·工业相机