欢迎光临
我们一直在努力

create table if not exists Waiting for table metadata lock

create table if not exists    Waiting for table metadata lock
版本mysql 5.5
现象:
mysql> show full processlist;
+—-+—————–+———–+——+———+———+———————————+————————————-+
| Id | User            | Host      | db   | Command | Time    | State                           | Info                                |
+—-+—————–+———–+——+———+———+———————————+————————————-+
|  1 | event_scheduler | localhost | NULL | Daemon  | 1661254 | Waiting on empty queue          | NULL                                |
|  4 | root            | localhost | test | Query   |      13 | Waiting for table metadata lock | create table if not exists a like t |
|  5 | root            | localhost | test | Sleep   |      32 |                                 | NULL                                |
|  7 | root            | localhost | NULL | Query   |       0 | NULL                            | show full processlist               |
+—-+—————–+———–+——+———+———+———————————+————————————-+

mysql> select * from information_schema.innodb_trx \G
Empty set (0.00 sec)

查不到锁。

重现:
session  1:
create table a (id int) engine=myisam;
begin;
select * from a;

session2 :
create table if not exists a like t;
….等待…..

session 3 :
mysql> show full processlist;
+—-+—————–+———–+——+———+———+———————————+————————————-+
| Id | User            | Host      | db   | Command | Time    | State                           | Info                                |
+—-+—————–+———–+——+———+———+———————————+————————————-+
|  1 | event_scheduler | localhost | NULL | Daemon  | 1661796 | Waiting on empty queue          | NULL                                |
|  5 | root            | localhost | test | Sleep   |      51 |                                 | NULL                                |
|  7 | root            | localhost | NULL | Query   |       0 | NULL                            | show full processlist               |
| 10 | root            | localhost | test | Query   |      40 | Waiting for table metadata lock | create table if not exists a like t |
+—-+—————–+———–+——+———+———+———————————+————————————-+
4 rows in set (0.00 sec)

mysql> select * from information_schema.innodb_trx \G
Empty set (0.00 sec)

如果a表的定义是innodb,就可以通过  select * from information_schema.innodb_trx \G 查询到记录

另:
5.6版本没有这个问题。

转载请注明源出处
QQ 273002188 欢迎一起学习
QQ 群 236941212
oracle,mysql,mongo 相互交流

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。