donglin7383 2017-02-10 20:19
浏览 355

使用FOR UPDATE时是否隐式使用READ COMMITTED事务隔离级别?

After scouring the internet for information about Transactional Isolation levels, I understood that Row Locking in MySQL can be achieved by using either SELECT...FOR UPDATE or LOCK IN SHARE MODE and also that, a row locking query must execute after starting the transaction. So I came across some example illustrating the implementation of READ COMMITTED isolation level for two sessions like this:

--session 1
SET TRANSACTION ISOLATION LEVEL READ COMMITTED;

BEGIN TRANSACTION;

SELECT FirstName FROM EmployeeInfo
WHERE EmpID = 1;

WAITFOR DELAY '00:00:05'  

SELECT FirstName FROM EmployeeInfo
WHERE EmpID = 1;

ROLLBACK TRANSACTION;

The code for session 2 is like so:

 --session 2
 UPDATE EmployeeInfo
 SET FirstName = 'Frank'
 WHERE EmpID = 1;

In the code sample for session1, the transaction Isolation level and the beginning of a transaction are explicit. In a certain blog I read that

  • UPDATE statements implicitly create READ locks on affected rows in a transaction. So does this means that I can safely omit SET TRANSACTION ISOLATION LEVEL READ COMMITTED; from session 1 and still get the same results.In other words how true is the statement UPDATE statements implicitly create READ locks on affected rows in a transaction.
  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
    • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
    • ¥30 截图中的mathematics程序转换成matlab
    • ¥15 动力学代码报错,维度不匹配
    • ¥15 Power query添加列问题
    • ¥50 Kubernetes&Fission&Eleasticsearch
    • ¥15 報錯:Person is not mapped,如何解決?
    • ¥15 c++头文件不能识别CDialog
    • ¥15 Excel发现不可读取的内容
    • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题