MYSQL 奇怪的幻读问题!!!

Mysql版本:5.6.27
事务隔离级别:Repeatable Read
导致出现问题的原因:timestamp 类型加了UPDATE CURRENT_TIMESTAMP

表结构:
CREATE TABLE `t_test` (
  `ID` bigint(20) NOT NULL AUTO_INCREMENT,
  `AMOUNT` smallint(6) DEFAULT NULL,
  `CREATED_TIME` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '创建时间',
  PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=21 DEFAULT CHARSET=utf8;


情景1:保留UPDATE CURRENT_TIMESTAMP配置
   前提:两个线程并发
   线程1:
      

          
  • 1. 开启事务
  •       
  • 2. 读取表select count(1) from t_test 结果为0
  •       
  • 3. 阻塞线程让线程2执行
  •       
  • 4. 更新表update t_test set AMOUNT = 10 返回执行的行数为1
  •       
  • 5. 读取表select count(1) from t_test 结果为0
  •       
  • 6. 事务结束
  •       


   线程2:
      

          
  • 1. 开启事务
  •       
  • 2. 插入数据 insert into t_test (AMOUNT) values (10)
  •       
  • 3. 事务结束
  •       


情景2:保留UPDATE CURRENT_TIMESTAMP配置
   前提:两个线程并发
   线程1:
      

          
  • 1. 开启事务
  •       
  • 2. 读取表select count(1) from t_test 结果为0
  •       
  • 3. 阻塞线程让线程2执行
  •       
  • 4. 更新表update t_test set AMOUNT = 5 返回执行的行数为1
  •       
  • 5. 读取表select count(1) from t_test 结果为1
  •       
  • 6. 事务结束
  •       


   线程2:
      

          
  • 1. 开启事务
  •       
  • 2. 插入数据 insert into t_test (AMOUNT) values (10)
  •       
  • 3. 事务结束
  •       



情景3:去除UPDATE CURRENT_TIMESTAMP配置
   前提:两个线程并发
   线程1:
      

          
  • 1. 开启事务
  •       
  • 2. 读取表select count(1) from t_test 结果为0
  •       
  • 3. 阻塞线程让线程2执行
  •       
  • 4. 更新表update t_test set AMOUNT = 10 返回执行的行数为1
  •       
  • 5. 读取表select count(1) from t_test 结果为1
  •       
  • 6. 事务结束
  •       


   线程2:
      

          
  • 1. 开启事务
  •       
  • 2. 插入数据 insert into t_test (AMOUNT) values (10)
  •       
  • 3. 事务结束
  •       

猜你喜欢

转载自xjywp2008.iteye.com/blog/2259442
今日推荐