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:
[list]
[*]1. 开启事务
[*]2. 读取表select count(1) from t_test 结果为0
[*]3. 阻塞线程让线程2执行
[color=red] [*]4. 更新表update t_test set AMOUNT = 10 返回执行的行数为1
[*]5. 读取表select count(1) from t_test 结果为0[/color]
[*]6. 事务结束
[/list]

线程2:
[list]
[*]1. 开启事务
[*]2. 插入数据 insert into t_test (AMOUNT) values (10)
[*]3. 事务结束
[/list]

情景2:保留UPDATE CURRENT_TIMESTAMP配置
前提:两个线程并发
线程1:
[list]
[*]1. 开启事务
[*]2. 读取表select count(1) from t_test 结果为0
[*]3. 阻塞线程让线程2执行
[color=red] [*]4. 更新表update t_test set AMOUNT = 5 返回执行的行数为1
[*]5. 读取表select count(1) from t_test 结果为1[/color]
[*]6. 事务结束
[/list]

线程2:
[list]
[*]1. 开启事务
[*]2. 插入数据 insert into t_test (AMOUNT) values (10)
[*]3. 事务结束
[/list]


情景3:去除UPDATE CURRENT_TIMESTAMP配置
前提:两个线程并发
线程1:
[list]
[*]1. 开启事务
[*]2. 读取表select count(1) from t_test 结果为0
[*]3. 阻塞线程让线程2执行
[color=red] [*]4. 更新表update t_test set AMOUNT = 10 返回执行的行数为1
[*]5. 读取表select count(1) from t_test 结果为1[/color]
[*]6. 事务结束
[/list]

线程2:
[list]
[*]1. 开启事务
[*]2. 插入数据 insert into t_test (AMOUNT) values (10)
[*]3. 事务结束
[/list]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值