当我们想删除一张表的全部数据时,我们可以使用 truncate 关键字,但如果要删除的表的主键被引用了,那么就无法执行语句。
1、制作清除数据的工具 ,在 nuget 控制台中输入 Install-Package TruncateATable -Version 1.0.0 ,该程序集使用非常简单,使用 TruncateATable.TruncateATableHelper 实例中的 TruncateATable(string tableName, string connStr)。
即可删除该表的数据及其关联表的数据。当然 如果其关联表自己仍有关联表的话也会被清空数据,再往下亦是如此。
2、使用清除数据工具, 安装包下载 TruncateATableSetUp 或在 github 上下载 release 版本: TruncateATable。
源码地址:https://github.com/zhuwansu/TruncateATable.git。
PS:目前仅支持 Oracle,不会重置 sequence 所以别忘自己修改。
工作中需要清除大量数据,使用 delete 太慢,所以抽时间写了一下,顺便练习一下 github 源码管理和 nuget 打包。
实现原理:f 表示实现函数,abc表示表,=>表示主键被引用,/=>表示禁用外键。 fa,a=>b, a/=>b,fb,b=>c,b/=>c,fc,c=>,fb,b=>c,fa,a=>b.
大致是一个递归, 禁用外键 ,清除数据 ,启用外键 。