我必要一点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 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)的提醒将不胜谢谢? >可以订购……限定……导致任何题目? >索引和密钥可以导致任何题目吗?
最佳谜底
在进一步相识之前要搜查的要害事项: >确保表引擎是InnoDB,不然“for update”不会锁定行,由于没有事宜. >确保正确行使“更新”成果.假如您选摘要更新的内容,则会锁定该事宜.固然其他事宜也许可以或许读取该行,可是在原始锁定事宜开释锁之前,不能选择任何其他事宜举办更新,更新或删除. >为了保持洁净,实行行使“START TRANSACTION”显式启动事宜,运行select“for update”,对要返回的记录执行任何操纵,并通过显式执行“COMMIT”来完成封锁买卖营业.
就我所知,订单和限定对您碰着的题目没有任何影响,Select将返回的是将被锁定的行.
答复你的题目:
????>是否可以在单独的一堆行(在统一个表中)中的两个单独的事宜中获取两个单独的锁? 是的,但不是在统一行.锁只能一次存在于一个事宜中的行级别. ????>我在第一次和第二次查询之间有多次碰撞(我有贫困调试,任何干于怎样调试SELECT … FROM(SELECT …)WHERE … IN(SELECT)的提醒将不胜谢谢? 计较行锁定的时刻也许很短,这将耽误第二个查询,可是除非您一次运行数百个这样的选择更新,不然不会导致任何重大或明明的耽误. ????>可以订购……限定……导致任何题目? 不是我的履历.它们应该像在正常的select语句中一样事变. ????>索引和密钥可以导致任何题目吗? 索引应始终存在以确保足够的机能,但它们不该导致得到锁定的任何题目.
(编辑:湖南网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|