由于选择查询而在桌面上获取锁定?

时间:2013-12-06 04:12:27

标签: mysql sql locking database-locking

我们长时间使用以下选择查询。 但今天我们在数据库上收到了很多锁。

请帮我解决因选择查询而导致的锁定问题。

表格大小非常小300kb。

我们优化了表但没有运气

从下面查询信息和表格结构。

Req-SQL:[select max(fullname) from prod_sets where name='view_v01' for update] 
Req-Time: 5 sec 
Blocker-SQL:[] 
Blocker-Command:[Sleep] 
Blocker-Time: 73 sec

Req-SQL:[select max(fullname) from prod_sets where name='view_v01' for update] 
Req-Time: 22 sec 
Blocker-SQL:[] 
Blocker-Command:[Sleep] 
Blocker-Time: 73 sec

CREATE TABLE `prod_sets` (
  `modified` datetime DEFAULT NULL,
  `create` datetime DEFAULT NULL,
  `name` varchar(50) COLLATE latin1_bin DEFAULT NULL,
  `fullname` decimal(12,0) DEFAULT NULL,
  UNIQUE KEY `idx_n` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE=latin1_bin

解释计划:

mysql> explain select max(fullname) from prod_sets where name='view_v01' for update;
+----+-------------+---------------+-------+---------------+----------+---------+-------+------+-------+
| id | select_type | table         | type  | possible_keys | key      | key_len | ref   | rows | Extra |
+----+-------------+---------------+-------+---------------+----------+---------+-------+------+-------+
|  1 | SIMPLE      | prod_sets     | const | idx_name      | idx_name | 53      | const |    1 |       |
+----+-------------+---------------+-------+---------------+----------+---------+-------+------+-------+
1 row in set (0.01 sec)

2 个答案:

答案 0 :(得分:0)

假设您知道FOR UPDATE的含义。名称是DEFAULT NULL是否有任何原因?如果没有,我想为PRIMARY KEY命名。 Innodb的PK是群集的,因此它可以更快地访问fullname

CREATE TABLE `prod_sets` (
  `modified` datetime DEFAULT NULL,
  `create` datetime DEFAULT NULL,
  `name` varchar(50) COLLATE latin1_bin DEFAULT NOT NULL,
  `fullname` decimal(12,0) DEFAULT NULL,
  PRIMARY KEY `idx_n` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE=latin1_bin

或者只需添加以下INDEX。

ALTER TABLE prod_sets ADD INDEX(name, fullname);

答案 1 :(得分:0)

如果要锁定表格的某些行,则必须在完成工作后明确解锁表格。

使用:     解锁表格;

或使用:     kill put_process_id_here;

请参阅这些链接以进一步阅读

http://dev.mysql.com/doc/refman/5.0/en/lock-tables.html

http://lmorgado.com/blog/2008/09/10/mysql-locks-and-a-bit-of-the-query-cache/