alter table mysql离线与否?

时间:2012-01-07 00:36:55

标签: mysql alter

我需要在当前表中添加一列。

这张桌子在白天和晚上都经常使用。我发现我需要使用此处找到的alter命令进行更改

http://dev.mysql.com/doc/refman/5.1/en/alter-table.html

我在开发服务器上测试过它。

我花了大约2个小时才完成。现在我想在生产服务器上执行它?

会阻止我的网站吗?

4 个答案:

答案 0 :(得分:14)

为什么不在网站上显示一条消息,说明您将从2012年1月7日午夜起执行维护。

这样,你不会破坏任何数据,你不会得到任何mysql错误。您执行ALTER并在完成后再次启动该站点(不要忘记您的代码以确保您拥有正确的字段等)。简单的解决方案。

Stackoverflow会这样做,为什么不是你的呢?

答案 1 :(得分:1)

是的,在ALTER TABLE期间,所有读取和写入都被阻止。如果您的网站需要使用该表,请求将会挂起。

试试pt-online-schema-change。它允许读取和写入继续,同时它会捕获在重组完成后对更改的表重放的更改。

在开发服务器上仔细测试,以便了解它的工作原理和预期结果。

答案 2 :(得分:0)

它不会阻止您的网站,但它可能会导致错误。

当然,如果不查看应用程序的所有代码,就无法回答这个问题。

如有疑问,最重要的是安排维护窗口。

答案 3 :(得分:-3)

  1. 让生产服务器指向生成数据库的dev db(或)镜像一段时间。
  2. 更改生产中的表格
  3. 部署与生产数据库(使用新属性)对话的代码
  4. P.S:我觉得这更安全,也是一种万无一失的方式(根据我的经验)。