- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下情况:
如果有一个带有 InnoDB 表的 MySQL 数据库,我用它来存储唯一数字。我启动一个事务,读取值(例如 1000471),将该值存储在另一个表中并更新增量值(100472)。现在我想避免其他人甚至在我的事务运行时读取值。
如果我使用纯 MySQL,我会这样做:
Exceute("LOCK tbl1 READ");
执行("SELECT ... from tbl1");
执行(“插入到 tbl2”);
执行("解锁表");
但由于我使用 SubSonic 作为 DAL,并且代码应该独立于 mysql,所以我必须使用 TransactionScope。
我的代码:
TransactionOptions TransOpt = new TransactionOptions();
TransOpt.IsolationLevel = System.Transactions.IsolationLevel.ReadCommitted;
TransOpt.Timeout = new TimeSpan(0, 2, 0);
using (TransactionScope ts = new TransactionScope(TransactionScopeOption.RequiresNew, TransOpt))
{
// Select Row from tbl1
// Do something
ts.Complete();
}
根据TransactionOptions的帮助
system.transactions.isolationlevel
我想要达到的效果可以用 IsolationLevel.ReadCommitted 实现,但我仍然可以从事务外部读取行(如果我尝试更改它,我会得到一个锁,所以事务正在运行)
有人有什么建议吗?使用 TransactionScope 甚至可以实现读锁
最佳答案
如果有人感兴趣,这就是 TransactionOptions 影响 MySql 的方式:
假设我有两种方法。
方法 1 启动一个事务,从我的表中选择一行,增加值并更新表。
方法2是一样的,但是在select和update之间我加了1000ms的sleep。
现在假设我有以下代码:
Private Sub Button1_Click(sender as Object, e as System.EventArgs) Handles Button1.Click
Dim thread1 As New Threading.Thread(AddressOf Method1)
Dim thread2 As New Threading.Thread(AddressOf Method2)
thread2.Start() // I start thread 2 first, because this one sleeps
thread1.Start()
End Sub
如果没有交易,这会发生:
线程2启动,读取值5,然后休眠,
线程1启动,读取值5,更新值6,
线程 2 也将值更新为 6。
作用:我有两次唯一编号。
我想要的:
线程2启动,读取值5,然后休眠,
thread1 启动,尝试读取值,但获得锁并休眠,
thread2 将值更新为 6,
线程1继续,读取值6,将值更新为7
这就是如何使用 TransactionScope 开始交易:
TransactionOptions Opts = new TransactionOptions();
Opts.IsolationLevel = IsolationLevel.ReadUncommitted;
// start Transaction
using (TransactionScope ts = new TransactionScope(TransactionScopeOption.RequiresNew, Opts))
{
// Do your work and call complete
ts.Complete();
}
那甚至可以管理分布式事务。如果抛出异常,则永远不会调用 ts.Complete,并且范围的 Dispose() 部分会回滚事务。
下面概述了不同的 IsolationLevels 如何影响交易:
关于c# - 将 TransactionScope 与 MySQL 和读锁一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/938801/
我有一个应用程序,我想将多个数据库保存到一个事务中。如果他们中的任何一个失败了,我想把整个事情都推回去。但是,我想在回滚事务之前知道其中哪些失败(或成功)。 我有一个带有内部循环的外部 Transac
我刚刚开始玩 Dapper。到目前为止我很喜欢它。 dapper 不能与 TransactionScope 一起使用吗?我注意到,即使我从不调用 TransactionScope.Complete,我
您好首先感谢您对这个问题的关注;有没有办法在c#中实现这样的事务 using (Transactionscope x=new Transactionscope ()) { Thead A()=>
这是使用事务范围的正确方法吗: 我有一个代表事物的一部分的对象: public class ThingPart { private DbProviderFactory connectionFa
我正在尝试找到在使用 NHibernate 的 Web 应用程序中处理事务的最佳解决方案。 我们使用 IHttpModule 并在 HttpApplication.BeginRequest 我们打开一
我面临以下问题: 在我的项目中,我在应用程序正在使用的同一个数据库中进行了错误登录。这意味着,如果发生错误,那么在每个 catch 中,都会将错误存储到 DB 中。 然而,问题是在使用事务时。发生错误
我想知道在处理多线程时如何正确使用 TransactionScope 类? 我们在主线程中创建一个新的作用域,然后生成几个工作线程,我们希望它们参与主作用域,因此,如果作用域从未完成,则在每个工作线程
任何人都可以给我一个关于使用 TransactionScope 和 NHibernate 的快速概述吗?我需要对 session /IEnlistmentNotification/等做一些特别的事情吗
如果我执行以下操作: Using scope = New TransactionScope() entries.Content.ReadAs(Of IList(Of WebMaint
当 TransactionScope 首次推出时,我在让它在我的开发机器 (XP) 和我们的数据库服务器 (Windows Server 2003) 之间工作时遇到了一些严重的问题。 当我进一步研究时
我在基于 Silverlight 和 RIA 服务的项目中使用 TransactionScope 类。每次我需要保存一些数据时,我都会创建一个 TransactionScope 对象,使用 Oracl
TransactionScope 是否适用于封闭的数据库连接? using (var transaction = new TransactionScope(TransactionScopeOption
我有两个 PL/SQL 存储过程,每个过程都处理自己的事务(开始/提交和发生错误时的回滚)。从 .Net 代码我调用这两个 SP,如下所示。 using (TransactionScope ts
我在我的应用程序中使用了 TransactionScope 类,因为我需要以交互方式、自然地执行一些操作(要么全部成功,要么全都不成功)。 由于此操作不仅与数据库相关,我通过实现 IEnlistmen
您好,有没有办法检查使用 TransactionScope 的事务是提交还是回滚? 最佳答案 在处理 TransactionScope 之前,实际的提交不会发生。如果 Commit 由于任何原因失败,
我有一个 Web 应用程序,许多用户在任何给定时刻都在使用它。从数据库的角度来看,他们在系统中移动时不断地从任意数量的表中写入和读取数据。此外,我们还有许多将数据导入该系统的流程。 今天,在调试导入过
我正在开发一个使用 C# 和 SQL Server 作为数据库的 .NET Web 应用程序,我是这两种技术的新手。当我尝试同时保存大量信息时遇到问题。 我的代码很简单: SqlConnectio
您好,我在我的应用程序的多个位置使用了 TransactionScope。喜欢: using (var scope = new TransactionScope()) { ToDo1(
我在服务器端代码 (WCF) 中使用 TransactionScope 类时遇到性能问题。 我的代码从客户端获取请求,创建 TransactionScope 并执行短操作(通常最多 100 毫秒)。
我正在处理一个几乎不存在事务的遗留项目,这会在出现错误时导致大量的部分提交。 SQL 调用混合了原始 ADO、Linq to Entities 和 EntityFramework,我想让它们在事务中运
我是一名优秀的程序员,十分优秀!