我正在使用带有ruby的datamapper将数据存储到某些表中.
有几个表有非常大量的信息,我想在用户“重建数据库”时清除它们(它基本上删除了所有内容并重新计算数据).
我最初尝试了Forum.all.destroy并为所有不同的表做了它,但我注意到其中一些只是没有从phpmyadmin中删除.我只能想象它因为外键.虽然我真的不知道,因为我的另一张表格已成功删除.更不用说,无论如何,id恰好只是’零’,所以键不会达到非常大的数字(如#500,000键).
然后我尝试使用下面的代码运行它,但由于“外键约束”,它没有清除表格.我想强迫它工作,因为我知道一个事实我正在清理所有相互依赖的表(我只是没有清除2个表,一个设置表和一个随机存储表,两者都没有使用外键).
到目前为止我有……
adapter = DataMapper.repository(:default).adapter
adapter.execute('TRUNCATE TABLE `forums`, `dates`, `remarks`');
这很好,除了mysql语法显然是错误的.所以这是第一件事
我在phpmyadmin中逐一做到这一点,当我这样做时,它说
Cannot truncate a table referenced in a foreign key constraint