mysql C SELECT … FOR UPDATE来自多个线程中的一个表
我有一个大约有40万条记录的表,我需要在每一行上运行两个不同的处理函数.
表结构恰如其分:
data (
`id`,`mtime`,--
|
我需要一点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 它们不应该同时修改同一行,但是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将返回的是将被锁定的行. 回答你的问题: >是否可以在单独的一堆行(在同一个表中)中的两个单独的事务中获取两个单独的锁? (编辑:长春站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- mysql – 使用LIKE搜索GROUP_CONCAT
- Mysql入门mysqld-nt: Out of memory (Needed 167
- Mysql实例完美解决MySQL通过localhost无法连接数
- MYSQL数据库Navicat查询结果不能修改的原因及解决
- MYSQL数据库mysql 报错This function has none o
- Mysql应用MySQL 数据库 ALTER命令讲解
- mysql int字段增长超过11位
- Mysql学习mysql修改自增长主键int类型为char类型
- mysql – 如果SELECT记录如果两个值之间的差值的
- java – JOIN中的相同列名在ResultSet中出现“找
