• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

C#代码实现分布式事务

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

需引用using System.Transactions;

建测试表

create table t1
(
   id int
)

建测试存储过程1

create proc prc1
as
begin tran
insert into t1 values(1)
commit
go

 

建测试存储过程2

 

create proc prc2
as
raiserror('error!',16,1)
go

 

 

示例代码

Database db = DatabaseFactory.CreateDatabase(); //连接第一个数据库
Database db1 = DatabaseFactory.CreateDatabase("con1");//连接第二个数据库

 

using (TransactionScope scope = new TransactionScope())
            {
                try
                {
                    db.ExecuteNonQuery(CommandType.Text, "prc1");  //t1表中有一行数据
                    db1.ExecuteNonQuery(CommandType.Text, "prc2");//抛异常
                }
                catch
                {
                    return;//返回 未提交 t1表中无数据
                }
                finally
                {
                    //
                }
                scope.Complete(); //提交
            }


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C#编程(五十六)----------可观察的集合ObservableCollection发布时间:2022-07-14
下一篇:
C#文件上传时判断图片文件格式发布时间:2022-07-14
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap