首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >插入从锁定行读取的值时出现的问题

插入从锁定行读取的值时出现的问题
EN

Stack Overflow用户
提问于 2019-01-09 20:35:16
回答 1查看 22关注 0票数 1

我有两个受事务约束的脚本:

第一个:

代码语言:javascript
复制
START TRANSACTION;
update product set price = 70;
SELECT SLEEP(20);
rollback;

第二个:

代码语言:javascript
复制
START TRANSACTION;
insert into product_order(product_id, amount, price) select id, amount, price from product;
commit;

当第一个事务处于“睡眠”状态时,第二个事务已开始执行。

因此,我预计第二个事务将在第一个事务的休眠期间执行。出乎意料的是,第二个事务一直在等待,直到第一个事务退出睡眠状态。我知道它与行锁定有关。但是我没有更新包含在第一个事务中的行。

我的问题是:这种行为的原因是什么,我如何摆脱它?

EN

回答 1

Stack Overflow用户

发布于 2019-01-09 20:42:46

看起来锁将在事务结束后释放(您不能读取数据,因为如果事务失败,数据库将不得不回滚到以前的状态)

在插入之前,您应该设置会话事务隔离级别,以便它可以读取未提交的数据:

代码语言:javascript
复制
SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;

START TRANSACTION;
insert into product_order(product_id, amount, price) select id, amount, price from product;
COMMIT;

SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54110325

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档