【发布时间】:2019-02-14 23:59:26
【问题描述】:
假设数据库中有这样的表:
id code
a8e09395-771c-4c6b-bb49-4921eeaf3927 2018-1
726b1390-b502-11e8-96f8-529269fb1459 2018-2
7a7ac7a6-b502-11e8-96f8-529269fb1459 2018-3
81758ea6-b502-11e8-96f8-529269fb1459 2019-1
假设有 多个 客户端写入此表。
对于“代码”列,我们希望确保它遵循strict“今年-nth”模式。
所有客户端都应使用的正确事务隔离级别是什么?
----更新----2018-09-11 11:31:24---------
START TRANSACTION;
SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE;
SET @code = (SELECT CODE
FROM hey
WHERE id = 123);
UPDATE hey
SET code = @code + 1
WHERE id = 123;
COMMIT;
对上述交易进行了快速测试。
我启动了 2 个控制台,然后运行了上面的代码,我将它们都运行到了读取代码列的行。
然后让其中一个更新代码列,它会等待锁定。
然后我让另一个更新代码列,它会死锁和回滚。
现在第一个锁已经解决,可以提交了。
所以看起来这种事务隔离可以防止他们互相踩脚,对吗?
【问题讨论】:
-
"对于“代码”列,我们希望确保它遵循严格的“今年第 n 年”模式。这无法通过事务隔离来解决。您可以做的是创建一个触发器,该触发器对代码列进行计数和更新,并向除代码列之外的每一列授予列权限。不确定是否撤销列权限会覆盖MySQL 文档中也没有解释表权限。
标签: mysql transactions increment isolation-level transaction-isolation