我试图理解事务是如何工作的,我遇到了一个对我来说没有多大意义的场景。我希望有人能帮我理解它。
我有两笔交易
事务1
BEGIN; update data set val = val + 1 where id = 1
事务2
BEGIN; select * from data
我打开了两个终端,开始第一个事务并运行更新查询。这假定为id为1的元组上的事务1提供了独占锁。
然后,在提交第一个事务之前,我在另一个终端中运行第二个查询。我预计它会停止,因为第一个事务具有排它锁,这将阻止该事务获取id为1的元组上的读锁。
但是,mysql运行select查询并返回“非脏”数据。
有人能给我解释一下my
我有多个源执行相同的mysql查询来获取和执行作业(源是不同的php脚本)。我想要得到与过去最远的工作,所以我使用这个查询:
SELECT * FROM jobs ORDER BY last_done ASC
现在我的问题是每个源都应该得到唯一的结果,这意味着如果一个源得到job1,这个作业应该得到last_done的更新,所以它再次位于表的底部,如果一个秒源执行查询,它不应该得到job1,而应该得到job2,依此类推。
我有一个问题,有时如果两个来源几乎同时调用,如果我在select之后单独更新,他们会得到相同的工作。
我怎样才能最好地做到不是两个资源查询在一起得到相同的工作?
根据隔离级别,可能演示不同选择行为的场景:
1) 0:00 Thread A runs a query that returns 1000 rows that takes 5 minutes to complete
2) 0:02 Thread B runs a query that returns the same 1000 rows
3) 0:05 Thread A updates the last 1 rows in this result set and commits them
4) 0:07 Thread B's query returns*
根据隔离级别的不同,#4中的
在我的服务类(它被注释为事务处理)中,我更新对象并将其保存为:
myObj.save(flush:true) //(Thread A, updates the value, Step A)
在此之后,对数据进行处理需要很长时间。在此过程中,域类中进行了大量更改,但这些更改在这里并不相关。因为所有这些处理都发生在同一个服务类中,所以它是单个事务的一部分。
同时,当所有这些处理进行时,另一个线程(它是另一个hibernate会话的一部分)访问
MyObj.findAll() //Thread B,在结果集中,我看到了更新的值。在Step A中更新的值,但是线程A尚未完成,因此更改尚未提交给数据
我有6个脚本/任务。它们每一个都启动一个MySQL事务,然后完成它的工作,这意味着从MySQL数据库中选择/UPDATE/INSERT/DELETE,然后回滚。
因此,如果数据库处于给定的S状态,则启动一个任务,当任务终止时,数据库返回到状态S。
当我按顺序启动脚本时,一切正常:
S......task 6<代码>H 216</代码><代码>H 117</代码>DB状态S<代码>H 218<//代码><代码>F 219<//代码>
但是我想通过多线程和并行启动脚本来加速这个过程。
DB at sta