分布式事物TransactionScope的正确用法

简介: 正确的写法应该如下如果A类是使用数据库资源的。class  A{SqlConnection cn=null;public A(){.....cn.open();}}//开始事务using(transactionscope scope=new transactionscope()){//要确保对支持事务的资源的登记放在此范围内,如数据库资源的打开A a=new A();a.method();.....scope.comlete()} 我们只要确保数据库的打开操作是在事务范围内打开就行了。

正确的写法应该如下

如果A类是使用数据库资源的。

class  A

{

SqlConnection cn=null;

public A()

{

.....

cn.open();

}

}

//开始事务

using(transactionscope scope=new transactionscope())

{

//要确保对支持事务的资源的登记放在此范围内,如数据库资源的打开

A a=new A();

a.method();

.....

scope.comlete()

}

我们只要确保数据库的打开操作是在事务范围内打开就行了。这样就可以做到事务的正确操作。

以前的代码是因为一个业务对象的初始化操作在外部进行了。尽管后来在事务范围内进行业务操作,也不行.

A a=new A();

using(transactionscope scope=new transactionscope())

{

//要确保对支持事务的资源的登记放在此范围内,如数据库资源的打开

a.method();

.....

scope.comlete()

}


上述代码,其实是没有参与任何事务的。对于子事务而已也是一样,只要保证事务登记在事务范围内才正确


其他参考文章:


.NET:脏读、不可重复读和幻读测试


http://www.cnblogs.com/happyframework/p/3284154.html

.NET:分布式事务


http://www.cnblogs.com/happyframework/p/4100106.html

目录
相关文章
|
9月前
|
供应链 NoSQL Java
关于Redisson分布式锁的用法
Redisson分布式锁是实现分布式系统中资源同步的有效工具。通过合理配置和使用Redisson的各种锁机制,可以确保系统的高可用性和数据一致性。本文详细介绍了Redisson分布式锁的配置、基本用法和高级用法,并提供了实际应用示例,希望对您在实际项目中使用Redisson分布式锁有所帮助。c
1401 10
|
设计模式 监控 安全
一文搞懂:zookeeper实现分布式锁安全用法
一文搞懂:zookeeper实现分布式锁安全用法
109 0
|
安全 Java API
Java从入门到精通:3.2.1分布式与并发编程——深入Java并发包,精通多线程高级用法
Java从入门到精通:3.2.1分布式与并发编程——深入Java并发包,精通多线程高级用法
160 1
|
SQL 安全 关系型数据库
17PostgreSQL shared nothing分布式用法讲解|学习笔记(三)
快速学习17PostgreSQL shared nothing分布式用法讲解
341 0
17PostgreSQL shared nothing分布式用法讲解|学习笔记(三)
|
安全 调度 数据中心
zookeeper 实现分布式锁安全用法
背景 ConnectionLoss 链接丢失 SessionExpired 会话过期 绕开 zookeeper broker 进行状态通知 leader 选举与zkNode 断开 做好幂等 静态扩容、动态扩容 背景 分布式锁现在用的越来越多,通常用来协调多个并发任务。
1834 0
|
18天前
|
存储 负载均衡 NoSQL
【赵渝强老师】Redis Cluster分布式集群
Redis Cluster是Redis的分布式存储解决方案,通过哈希槽(slot)实现数据分片,支持水平扩展,具备高可用性和负载均衡能力,适用于大规模数据场景。
109 2
|
2月前
|
存储 缓存 NoSQL
Redis核心数据结构与分布式锁实现详解
Redis 是高性能键值数据库,支持多种数据结构,如字符串、列表、集合、哈希、有序集合等,广泛用于缓存、消息队列和实时数据处理。本文详解其核心数据结构及分布式锁实现,帮助开发者提升系统性能与并发控制能力。
|
6月前
|
数据采集 存储 数据可视化
分布式爬虫框架Scrapy-Redis实战指南
本文介绍如何使用Scrapy-Redis构建分布式爬虫系统,采集携程平台上热门城市的酒店价格与评价信息。通过代理IP、Cookie和User-Agent设置规避反爬策略,实现高效数据抓取。结合价格动态趋势分析,助力酒店业优化市场策略、提升服务质量。技术架构涵盖Scrapy-Redis核心调度、代理中间件及数据解析存储,提供完整的技术路线图与代码示例。
556 0
分布式爬虫框架Scrapy-Redis实战指南
|
2月前
|
NoSQL Redis
Lua脚本协助Redis分布式锁实现命令的原子性
利用Lua脚本确保Redis操作的原子性是分布式锁安全性的关键所在,可以大幅减少由于网络分区、客户端故障等导致的锁无法正确释放的情况,从而在分布式系统中保证数据操作的安全性和一致性。在将这些概念应用于生产环境前,建议深入理解Redis事务与Lua脚本的工作原理以及分布式锁的可能问题和解决方案。
105 8
|
4月前
|
数据采集 存储 NoSQL
基于Scrapy-Redis的分布式景点数据爬取与热力图生成
基于Scrapy-Redis的分布式景点数据爬取与热力图生成
275 67

热门文章

最新文章