为什么我的团队中没有TRUNCATE?即使我有一个删除级联集,我得到:

错误1701(42000):无法截断外键约束(mytest.instance,constraint instance_ibfk_1 foreign key(GroupID)REFERENCES mytest.mygroup(ID))中引用的表

drop database mytest;
create database mytest;
use mytest;

CREATE TABLE mygroup (
   ID    INT NOT NULL AUTO_INCREMENT PRIMARY KEY
) ENGINE=InnoDB;

CREATE TABLE instance (
   ID           INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
   GroupID      INT NOT NULL,
   DateTime     DATETIME DEFAULT NULL,

   FOREIGN KEY  (GroupID) REFERENCES mygroup(ID) ON DELETE CASCADE,
   UNIQUE(GroupID)
) ENGINE=InnoDB;

当前回答

你能做到的

DELETE FROM `mytable` WHERE `id` > 0

其他回答

在MYSQL数据库上测试

解决方案1:

SET FOREIGN_KEY_CHECKS = 0;
TRUNCATE table1;

解决方案2:

DELETE FROM table1;
ALTER TABLE table1 AUTO_INCREMENT = 1;
TRUNCATE table1;

这对我有用。我希望,这对你也有帮助。谢谢你提出这个问题。

不能TRUNCATE应用了FK约束的表(TRUNCATE与DELETE不同)。

要解决此问题,请使用以下任一解决方案。两者都存在破坏数据完整性的风险。

选项1:

移除约束执行TRUNCATE手动删除现在无处引用的行创建约束

选项2:由用户447951在回答中建议

SET FOREIGN_KEY_CHECKS = 0; 
TRUNCATE table $table_name; 
SET FOREIGN_KEY_CHECKS = 1;

我只需要:

DELETE FROM mytest.instance;
ALTER TABLE mytest.instance AUTO_INCREMENT = 1;

如果您使用的是laravel迁移,可以使用facade助手来实现

更喜欢使用雄辩的对象,回答“雄辩”的方式

 Schema::disableForeignKeyConstraints();
 Teacher::truncate();
 Schema::enableForeignKeyConstraints();

在Laravel 7和8中,为了兼容4个数据库(MySql、Postgres、SQLite和SqlServer),并且没有Elquent,您可以使用:

Schema::disableForeignKeyConstraints();
    DB::table('teachers')->truncate();
Schema::enableForeignKeyConstraints();

虽然有人问我这个问题,但我不知道,但现在如果您使用phpMyAdmin,您只需打开数据库并选择要截断的表即可。

底部有一个下拉列表,包含许多选项。打开它并选择标题“删除数据或表格”下的“空”选项。它会自动转到下一页,在复选框中有一个名为“启用外键检查”的选项。只需取消选中它,然后按“是”按钮,所选表格将被截断。

也许它在内部运行user447951答案中建议的查询,但从phpMyAdmin界面使用它非常方便。