mysql 多线程 update_mysql – SELECT … FOR UPDATE来自多个线程中的一个表

这篇博客讨论了在MySQL中使用多线程和SELECT...FOR UPDATE语句处理40万条记录的问题。文章描述了两个并发执行的功能,一个按priority1快速遍历所有记录,另一个按priority2对未处理记录进行慢速处理。作者遇到的问题是两个查询似乎不能同时返回数据,并寻求关于并发锁、查询调试和索引影响的建议。
摘要由CSDN通过智能技术生成

我需要一点

SELECT FOR UPDATE (resp. LOCK IN SHARE MODE)的帮助.

我有一个大约有40万条记录的表,我需要在每一行上运行两个不同的处理函数.

表结构恰如其分:

data (

`id`,

`mtime`, -- When was data1 set last

`data1`,

`data2` DEFAULT NULL,

`priority1`,

`priority2`,

PRIMARY KEY `id`,

INDEX (`mtime`),

FOREIGN KEY ON `data2`

)

功能有点不同:

>第一个函数 – 必须在所有记录上循环运行(非常快),应该根据priority1选择记录;设置data1和mtime

>第二个函数 – 每个记录只需运行一次(非常慢),应根据priority2选择记录;设置data1和mtime

它们不应该同时修改同一行,但是select可能会在它们中返回一行(priority1和priority2具有不同的值)并且如果是这样的话,事务可以等待(我希望这将是它阻止的唯一情况.

我正在根据以下查询选择数据:

-- For the first function - not processed first, then the oldest,

-- the same age goes based on priority

SELECT id FROM data ORDER BY mtime IS NULL DESC, mtime, priority1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值