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;
}
相关推荐
R-G-B2 小时前
【33】C# WinForm入门到精通 ——表格布局器TableLayoutPanel【属性、方法、事件、实例、源码】
开发语言·c#·c# winform·表格布局器·tablelayoutpane
freesheep7202 小时前
WPF使用PreviewTextInput事件限制用户输入
c#·wpf
Yueeyuee_4 小时前
【C#学习Day16笔记】XML文件、 事件Event 、Json数据
笔记·学习·c#
钢铁男儿8 小时前
C# 枚举器和迭代器(常见迭代器模式)
数据库·c#·迭代器模式
R-G-B10 小时前
【05】VM二次开发——模块参数配置--带渲染/不带渲染(WinForm界面调用 模块参数配置)
c#·vm二次开发·vm模块参数配置·vm在winform界面调用
R-G-B17 小时前
【12】大恒相机SDK C#开发 ——多相机开发,枚举所有相机,并按配置文件中的相机顺序 将所有相机加入设备列表,以便于对每个指定的相机操作
c#·大恒相机sdk·大恒多相机开发·大恒多相机枚举·大恒多相机指定顺序
R-G-B17 小时前
【13】大恒相机SDK C#开发 —— Fom1中实时处理的8个图像 实时显示在Form2界面的 pictureBox中
c#·大恒相机sdk·图像实时显示在另一个界面
向宇it1 天前
【unity小技巧】封装一套 Unity 的植物生长系统
游戏·unity·c#·游戏引擎
NFA晨曦1 天前
力扣刷题日常(7-8)
算法·leetcode·c#
踏上青云路1 天前
C# 闭包
java·前端·c#