我有一个大约有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 LIMIT 250 FOR UPDATE;
-- For the second function - only processed not processed order by priority
SELECT if FROM data ORDER BY priority2 WHERE data2 IS NULL LIMIT 50 FOR UPDATE;
但我所经历的是,每次只有一个查询返回.
所以我的问题是:
>是否可以在单独的一堆行(在同一个表中)中的两个单独的事务中获取两个单独的锁?
>我在第一次和第二次查询之间有多次碰撞(我有麻烦调试,任何关于如何调试SELECT … FROM(SELECT …)WHERE … IN(SELECT)的提示将不胜感激?
>可以订购……限制……导致任何问题?
>索引和密钥可以导致任何问题吗?
7051

被折叠的 条评论
为什么被折叠?



