mysql导入数据表卡住_导入数据库转储时挂起mysql

我们的生产数据库中有一个数据库转储导入脚本,可用于重建沙箱数据库.我们为此使用的语法是mysql -u uname -ppass dbname< prod_db_export.sql.该脚本继续创建第一个表,然后执行以下操作:

LOCK TABLES `ad` WRITE;

/*!40000 ALTER TABLE `ad` DISABLE KEYS */;

/*!40000 ALTER TABLE `ad` ENABLE KEYS */;

UNLOCK TABLES;

表格广告中没有数据,因此DISABLE KEYS行之后没有import语句.无论如何,导入此时就挂起了,当我们使用processlist查询数据库时,会看到如下输出:

| 5116 | uname | localhost | dbname | Field List | 85 | Waiting for table | |

| 5121 | uname | localhost | dbname | Query | 44 | Waiting for table | LOCK TABLES `ad` WRITE |

| 5126 | uname | localhost | dbname | Field List | 23 | Waiting for table | |

有人知道会导致这种情况发生的原因吗?更好的是,如何解决呢?

我们的SA根本不希望重新启动mysql,因为他担心它将无法重新启动(这是上次发生类似情况时发生的情况,他不得不重建整个数据库,包括所有沙箱的数据库. ,来自备份).

随后,我们创建了一个新数据库dbname2,并且能够在processlist中没有挂起,没有表锁定消息的情况下成功运行导入.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值