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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Tomcat日志乱码问题

    Tomcat日志乱码问题昨天本来准备更新一下Tomcat版本,但是发现新版本的日志打印中文会出现乱码(Tomcat自身打印的日志),不管是使用bat脚本启动还是在Idea中启动,都是乱码。研究了一个晚上,百度上的那些方式都试遍了,都是设置各种JVM启动参数,发现并没有卵用。在使用bat文件启动Tomcat时,Tomcat目录下的logs文件夹会生成相应的日志文件,发现旧版本生成的日志文件编码是GBK,而Windows控…

    2022年6月20日
    40
  • JavaScript 开发者年度调查报告

    JavaScript 开发者年度调查报告

    2022年3月3日
    43
  • 爬虫系列,(3),达盖尔图片抓取

    爬虫系列,(3),达盖尔图片抓取importreimportrequestsfrombs4importBeautifulSoup#第一步得到代理defproxy():withopen(r’ip_proxies\有效ip.txt’,’r’,encoding=’utf-8′)asf:r=f.readlines()foripinr:…

    2022年6月24日
    33
  • 7628刷breed_我的刷breed机方法 一步一图超详细

    7628刷breed_我的刷breed机方法 一步一图超详细本帖最后由航校门口二楼修于 2019 10 2517 35 编辑刷机前请恢复一下出厂设置 不然会变砖 首先感谢各路大神提供的工具和方法我的是 win764 位系统 有坛友反应 win10WinSCP 无法上传文件连接不了 关掉 win10 防火墙就好方法请百度 路由器固件版本 22 23 1 108 路由器用网线连接电脑无线连接刷机必变砖所有用到的工具下载 openwrt k2t initr

    2025年8月29日
    3
  • 生成模型_常见的模型生成方式

    生成模型_常见的模型生成方式(一)生成模型简介1、什么是生成模型在概率统计理论中,生成模型是指能够在给定某些隐含参数的条件下,随机设工程观测数据的模型,他给观测值和标测数据序列指定一个联合概率分布,在机器学习中,生成模型可以

    2022年8月1日
    7
  • 代理IP池(sqlmap外部代理ip池)

    这些公共代理是完全免费提供的,不需要任何授权。免费代理通常是开放的、流行的公共代理。与私人代理不同,公共代理不需要注册或密码。事实上,它们是负责安装在计算机上的代理服务器并且不关心更改默认设置的系统管理员的错误或疏忽。因此,服务器通过特殊的扫描仪快速定位到网络中,成为渴望匿名的公众的财产。这些信息足以安全地浏览全球网络,而无需显示您的真实IP地址。这些代理有很大的优势:他们有一个简单的设置-这些代理不需要授权并且设置简单他们是免费的!没有流量限制或使用目的但是,除了所有这些优点之外,这

    2022年4月14日
    210

发表回复

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

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