CSFramework.EF 数据库框架 - 使用 BeginTransation 方法启动事务


C# 全选
//
//测试事务2,www.csframework.com
//
string connString = "Server=127.0.0.1;Database=CSFrameworkV6_Normal;User ID=demo_webapi;Password=test; Max Pool Size=512; Pooling=true;Connect Timeout=30;TrustServerCertificate=true;";
IDatabase db = DatabaseFactory.GetDatabase(DatabaseType.SqlServer, connString);

var list = db.GetQueryable<tb_PO>().OrderByDescending(o => o.PODate).Take(10).ToList();

var result = "";

try
{
    db.BeginTransaction();

    //修改第1条
    var obj = list.First();
    obj.Remark = "RunTransaction修改了:" + obj.Remark;
    result += db.Update<tb_PO>(obj);

    //删除最后1条
    result += db.Remove(list.Last());

    //add
    var newObj = new tb_PO();
    newObj.ISID = IdHelper.GetId();
    newObj.PODate = DateTime.Now;
    newObj.PONO = DocNoHelper.GetDocNo(db, "EF", 8, "admin");
    newObj.CustomerCode = DocNoHelper.GetDataSN(db, "EF", true, 8, "-");
    newObj.Remark = DocNoHelper.GetDataSN(db, "DB", true, 8, "-");
    result += db.Add<tb_PO>(newObj);

    //抛出异常
    int div = 0;
    var r = 1 / div;

    db.CommitTransaction();
}
catch
{
    db.RollbackTransaction();
    throw;
}
版权声明:本文为开发框架文库发布内容,转载请附上原文出处连接
C/S框架网
上一篇:CSFramework.EF 数据库框架 - 使用 RunTransaction 启动事务
下一篇:ExecuteSql 执行SQL存储过程
评论列表

发表评论

评论内容
昵称:
关联文章

CSFramework.EF 数据库框架 - 使用 BeginTransation 方法启动事务
CSFramework.EF 数据库框架 - 使用 RunTransaction 启动事务
CSFramework.EF数据库框架简介
CSFramework.EF 数据库框架 - Demo测试程序
CSFramework.EF 数据库框架 - 获取数据库元数据 (meta方法)
CSFramework.EF 数据库框架 - 测试同步方法
CSFramework.EF 数据库框架 - 测试 Add 方法新增对象
主程序集成CSFramework.EF 数据库框架
CSFramework.EF ModelBuilder/OnModelCreating方法详解
DAL层重写Update方法手工启动事务
CSFramework.EF 数据库框架 - 测试 Remove 方法删除对象
CSFramework.EF 数据库框架 - 测试异步方法 (Async)
CSFramework.EF 数据库框架 - 测试 Update 方法更新对象
CSFramework.WebApiV3.CSFramework.EF 组件使用
CSFramework.WebApiV3.CSFramework.EF 组件使用
EntityFrameworkCore EF ModelBuilder/OnModelCreating方法详解
CSFramework.EF数据库初始化
CSFrameworV6试用版开发指南 - Main主程序安装CSFramework.EF数据库框架
CSFramework.EF 数据库框架 - 测试 BulkInsert 方法极速插入对象
IDatabase接口使用事务DbTransaction实例