为什么我的团队中没有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;

当前回答

根据mysql文档,TRUNCATE不能用于具有外键关系的表。没有完整的替代AFAIK。

删除约束仍然不会调用ON DELETE和ON UPDATE。我能想到的唯一解决方案是:

删除所有行,删除外键,截断,重新创建键删除所有行,重置auto_increment(如果使用)

MySQL中的TRUNCATE似乎还不是一个完整的功能(它也不会调用触发器)。参见注释

其他回答

如果您使用的是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,那么很简单。

只需取消选中SQL选项卡下的启用外键检查选项,然后运行TRUNCATE<TABLE_NAME>

你能做到的

DELETE FROM `mytable` WHERE `id` > 0

答案确实是zerkms提供的,如选项1所述:

选项1:不会对数据完整性造成损害:移除约束执行TRUNCATE手动删除现在无处引用的行创建约束

棘手的部分是消除约束,所以我想告诉你,如果有人需要知道如何做到这一点:

运行SHOW CREATE TABLE<TABLE Name>查询以查看FOREIGN KEY的名称(下图中的红色框):运行ALTER TABLE<表名>DROP FOREIGN KEY<外键名>。这将删除外键约束。删除关联的索引(通过表结构页),就完成了。

要重新创建外键:

ALTER TABLE <Table Name>
ADD FOREIGN KEY (<Field Name>) REFERENCES <Foreign Table Name>(<Field Name>);

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

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

选项1:

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

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

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