transactionscope mysql_TransactionScope事务对多个数据库的操作[通俗易懂]

transactionscope mysql_TransactionScope事务对多个数据库的操作[通俗易懂].Net2.0引入了轻量级事务管理器(LighweightTransactionManager),即System.Transactions.TransactionManager。轻量级事务管理器具有最小的开销,对比使用轻量级事务管理器的事务和直接使用本地事务,并没有性能上的差别。如果一个事务里只有一个资源管理器,轻量级事务管理器可以让资源管理器来管理该事务,而轻量级事务管理器只负责监视他;如…

大家好,又见面了,我是你们的朋友全栈君。

.Net 2.0引入了轻量级事务管理器(Lighweight Transaction Manager),即System.Transactions.TransactionManager。

轻量级事务管理器具有最小的开销,对比使用轻量级事务管理器的事务和直接使用本地事务,并没有性能上的差别。

如果一个事务里只有一个资源管理器,轻量级事务管理器可以让资源管理器来管理该事务,而轻量级事务管理器只负责监视他;如果轻量级事务管理器发现有另外一个资源管理器被加入到事务中,轻量级事务管理器则会让原来的资源管理器释放控制权,并将控制权交给分布式事务处理器协调。

控制权在事务还在进行时转移给分布式事务处理协调器的这个过程称为事务升级(promotion pf a transaction)。

使用Demo

1)在要程序中添加system.TransAction.dll程序集的引用。如图:

abd0b6dd1d50368671c2940b08ee0501.png

2)使用TransActionScope。

using (TransactionScope tan = new TransactionScope())

{

//向第一个数据库的Fm_ArticlePro添加一条数据

RySfEntities db1 = new RySfEntities();

Fm_ArticlePro fmArticle = new Fm_ArticlePro();

fmArticle.FArP_DepID = ;

fmArticle.FArP_DepName = “ceshi”;

fmArticle.FArP_Time = DateTime.Now.ToLongTimeString();

db1.Fm_ArticlePro.Add(fmArticle);

db1.SaveChanges();

//int n = 0;

//int m = 9/n;//故意制造错误来测试是否插入数据

//向另外一个数据库Department表添加一条数据

ESIMSDataEntities1 db2 = new ESIMSDataEntities1();

Department d = new Department();

d.Dept_ID = ;

d.Dept_Description = DateTime.Now.ToLongTimeString();

d.Dept_Name = “ceshi”;

db2.Department.Add(d);

db2.SaveChanges();

tan.Complete();

}

3)启动DTC服务。

桌面右击“计算机” —> 管理 —> 服务和应用程序 —> 服务。

2d6de802736003282ff2bbb0bedb9d25.png

或者用命令启动:net start msdtc;

4)运行测试。

总结:很多时候,我们都只是做了第一步和第二步,而忘记启动协调跨多个数据库的DTC服务。这样就会出现一个错误,如下。

—————————

—————————

错误:基础提供程序在 Open 上失败。

—————————

确定

—————————

出现错误了数据也不会被插入到数据库。

说明:在步骤2)中是使用的隐式方法(使用system.Transactions.TransactionScope类),该方法更加灵活,因此更加适合。显示方法会使用system.Transactions.CommittableTransaction类。

(四)SQL入门 数据库的操作与事务管理

数据库的操作,有三个最基本的语句,insert插入,update修改,delete删除. 不同的数据库厂商的实现可能不同,所以就不说具体的语法怎么写的了.说语法也没有意义,到处都可以复制粘贴,记得听某 …

spring对数据库的操作、spring中事务管理的介绍与操作

jdbcTemplate的入门 创建maven工程 此处省略 导入依赖

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161931.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • jquery ajax 请求中多出现一次OPTIONS请求及其解决办法

    jquery ajax 请求中多出现一次OPTIONS请求及其解决办法

    2021年10月13日
    44
  • docker 上传本地镜像_不同docker仓库镜像同步

    docker 上传本地镜像_不同docker仓库镜像同步前言之前通过docker搭建过jenkins+python3环境,如果想要在不同的机器上搭建一样的环境,就可以将之前搭建的镜像上传到镜像仓库,这样方便在不同的机器上快速搭建同一套环境。如果公开的话

    2022年7月30日
    5
  • SIFT 尺度空间

    SIFT 尺度空间   最近也注意一些图像拼接方面的文章,很多很多,尤其是全景图拼接的,实际上类似佳能相机附加的软件,好多具备全景图拼接,多幅图像自动软件实现拼接,构成(合成)一幅全景图像(风景)。Sift算法,我略知一二,无法仔细描述(刚也贴了2个最近的资料)。     当就尺度空间(scalespace),我想,其在计算机视觉(ComputerVision)/图像的多分辨率分析(尤其近年来小波的多分

    2022年10月10日
    4
  • apache 负载均衡_apache部署

    apache 负载均衡_apache部署[1]Apache负载均衡设置方法mod_proxy使用介绍一般来说,负载均衡就是将客户端的请求分流给后端的各个真实服务器,达到负载均衡的目的。还有一种方式是用两台服务器,一台作为主服务器(Master),另一台作为热备份(HotStandby),请求全部分给主服务器,在主服务器当机时,立即切换到备份服务器,以提高系统的整体可 第一次看到这个标题时我也很惊讶,Apache居然还能做负载

    2022年9月9日
    3
  • 粒子群算法(PSO)的Python实现(求解多元函数的极值)

    粒子群算法(PSO)的Python实现(求解多元函数的极值)PSO是寻优算法中比较简单的一种,本文用Python简单实现了PSO算法,用来求解一个五元函数的最大值,并与MATLAB的fmincon函数的运行结果做比较。

    2022年4月29日
    182

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号