TransactionScope:为什么某些机器上会发生 MSDTC 升级
TransactionScope 提高了数据访问层的事务性能。 然而,一个常见的问题是 MSDTC 升级在开发人员计算机上不一致。 本文探讨原因及解决方案。
MSDTC 升级的原因
MSDTC 升级发生在以下情况:
- 一个事务中涉及多个缺乏单阶段提交支持的持久资源(例如数据库)。
- 一笔事务跨越多个应用程序域或进程,需要序列化。
故障排除和解决方案
调查揭示了一个关键区别:没有升级的开发人员使用 SQL Server 2008,而遇到升级的开发人员则使用 SQL Server 2005。
SQL Server 2005 与 SQL Server 2008
SQL Server 2008:
- 通常支持单个 TransactionScope 内的多个连接,前提是它们不是同时打开。
- 但是,嵌套连接或到不同资源的连接仍可能导致升级。
SQL Server 2005:
- 是否不支持TransactionScope内的多个连接。 任何额外的连接尝试都会触发 MSDTC 升级。
对于 SQL Server 2005,在整个 TransactionScope 中维护单个全局范围的开放连接可以避免升级。 然而,这与延迟连接打开和迅速关闭的最佳实践相矛盾。
需要考虑的其他要点:
- 即使使用 SQL Server 2008,使用
SqlTableAdapter
并预先打开其连接也可能会过早终止事务,从而导致升级。 - 虽然使用 ADO.NET 事务对象的自定义 TransactionScope 实现可以绕过升级,但它需要大量的开发工作。
以上是为什么我的 TransactionScope 在某些计算机上自动升级到 MSDTC?的详细内容。更多信息请关注PHP中文网其他相关文章!

本文详细介绍了C函数返回类型,包括基本(int,float,char等),派生(数组,指针,结构)和void类型。 编译器通过函数声明和返回语句确定返回类型,执行

Gulc是一个高性能的C库,优先考虑最小开销,积极的内衬和编译器优化。 其设计非常适合高频交易和嵌入式系统等关键应用程序,其设计强调简单性,模型

本文解释了C函数声明与定义,参数传递(按值和指针),返回值以及常见的陷阱,例如内存泄漏和类型不匹配。 它强调了声明对模块化和省份的重要性

本文详细介绍了字符串案例转换的C功能。 它可以通过ctype.h的toupper()和tolower()解释,并通过字符串迭代并处理零终端。 常见的陷阱,例如忘记ctype.h和修改字符串文字是

本文研究C函数返回值存储。 较小的返回值通常存储在寄存器中以备速度;较大的值可能会使用指针来记忆(堆栈或堆),影响寿命并需要手动内存管理。直接ACC

本文分析了形容词“独特”的多方面用途,探索其语法功能,常见的短语(例如,“不同于”,“完全不同”),以及在正式与非正式中的细微应用

本文解释了C标准模板库(STL),重点关注其核心组件:容器,迭代器,算法和函子。 它详细介绍了这些如何交互以启用通用编程,提高代码效率和可读性t

本文详细介绍了c中有效的STL算法用法。 它强调了数据结构选择(向量与列表),算法复杂性分析(例如,std :: sort vs. std vs. std :: partial_sort),迭代器用法和并行执行。 常见的陷阱


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 Linux新版
SublimeText3 Linux最新版

记事本++7.3.1
好用且免费的代码编辑器

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

Dreamweaver CS6
视觉化网页开发工具