关于mysql:如何正确截断表?

How do I truncate tables properly?

我正在使用带有ruby的datamapper将数据存储到某些表中。

有几个表有非常大量的信息,我想在用户"重建数据库"时清除它们(它基本上删除了所有内容并重新计算数据)。

我最初尝试使用Forum.all.destroy并为所有不同的表做了它,但我注意到其中一些只是没有从phpmyadmin中删除。我只能想象它因为外键。虽然我真的不知道,因为我的其他表格已成功删除。更不用说,无论如何,它只是'零',所以键不会达到非常大的数字(如#500,000键)。

然后我尝试使用下面的代码运行它,但由于"外键约束",它没有清除表格。我想强迫它工作,因为我知道一个事实我正在清理所有相互依赖的表(我只是没有清除2个表,一个设置表和一个随机存储表,两者都没有使用外键)。

到目前为止我有......

1
2
adapter = DataMapper.repository(:default).adapter
adapter.execute('TRUNCATE TABLE `forums`, `dates`, `remarks`');

这很好,除了mysql语法显然是错误的。所以这是第一件事

我在phpmyadmin中逐一做到这一点,当我这样做的时候,它说

1
Cannot truncate a table referenced in a foreign key constraint


计划A:

1
2
3
4
5
SET FOREIGN_KEY_CHECKS = 0; -- Disable foreign key checking.
TRUNCATE TABLE forums;
TRUNCATE TABLE dates;
TRUNCATE TABLE remarks;
SET FOREIGN_KEY_CHECKS = 1; -- Enable foreign key checking.

B计划:

您应首先截断子表,然后截断父表。

禁用外键检查可能会在表中输入不符合可能导致未定义行为的约束的行。


而不是使用禁用外键检查。

您可以使用以下代码。

1
2
3
4
5
6
7
8
DELETE FROM forums;
ALTER TABLE forums AUTO_INCREMENT = 1;

DELETE FROM dates;
ALTER TABLE dates AUTO_INCREMENT = 1;

DELETE FROM remarks;
ALTER TABLE remarks AUTO_INCREMENT = 1;

它将删除所有行并从1开始使id增加。