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)
上一篇 2022年7月24日 下午7:46
下一篇 2022年7月24日 下午8:00


相关推荐

  • 【JS】不同发布地址页面跳转[通俗易懂]

    【JS】不同发布地址页面跳转[通俗易懂]在使用html+json构建页面时,页面的跳转常用location.href完成当然,也有些直接在a标签的href中完成本来很简单的事,但是发布方式不同,就会一起一些问题,主要是页面路径跳转问题===========================================================列如,制作了两个网站html,同时放在WebSite这个文件夹下这两个网站都是一样的目录…

    2022年5月22日
    49
  • dig(域信息搜索器)命令

    dig(域信息搜索器)命令

    2021年10月14日
    51
  • 用Java IO流实现下载文件

    用Java IO流实现下载文件  @RequestMapping(value="download")   publicStringdownload(HttpServletResponseresponse,Modelmodel){             //通过文件名找出文件的所在目录      StringURL="D:/one/two.txt";      //得到要下载的文件…

    2022年5月30日
    52
  • 月之暗面Kimi K2宣布更新:上下文长度扩展至256K,带来更快的API

    月之暗面Kimi K2宣布更新:上下文长度扩展至256K,带来更快的API

    2026年3月12日
    1
  • 使用yum卸载、安装jdk

    使用yum卸载、安装jdk由于EPICS工作环境下安装CSS,但CSS不支持开源jdk,所以首先需要卸载openjdk,然后再安装jdk-8u144-linux-x64.tar.gz(CSS只支持8及以上版本)。一、卸载,需卸载干净,不然会出各种覆盖问题,很麻烦!安装好的CentOS会自带OpenJdk,用命令java-version,会有下面的信息:javaversion"1.6.0"OpenJDK Run…

    2022年6月6日
    64
  • c++中vector的用法详解_vector>初始化

    c++中vector的用法详解_vector>初始化vector()的用法概念vector是向量类型,它可以容纳许多类型的数据,如若干个整数,所以称其为容器。vector是C++STL的一个重要成员,使用它时需要包含头文件:#include<vector>;一、vector的初始化(1)vector<int>a(10);//定义了10个整型元素的向量(尖括号中为元素类型名,它可以是任何合法的数据类型),但没有给出初值,其值是不确定的。测试#include<iostream>#include&

    2025年11月21日
    5

发表回复

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

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