码迷,mamicode.com
首页 > 其他好文 > 详细

TruncateATable 清除一张表

时间:2017-11-11 15:59:56      阅读:201      评论:0      收藏:0      [点我收藏+]

标签:也会   oracle   seq   version   代码   外键   程序   关键字   rac   

  当我们想删除一张表的全部数据时,我们可以使用 truncate 关键字,但如果要删除的表的主键被引用了,那么就无法执行语句。

  1、制作清除数据的工具 ,在 nuget 控制台中输入 Install-Package TruncateATable -Version 1.0.0 ,该程序集使用非常简单,使用 TruncateATable.TruncateATableHelper 实例中的 TruncateATable(string tableName, string connStr)。

即可删除该表的数据及其关联表的数据。当然 如果其关联表自己仍有关联表的话也会被清空数据,再往下亦是如此。

  2、使用清除数据工具, 在 github 上可以下载源代码和最初的 release 版本: TruncateATablehttps://github.com/zhuwansu/TruncateATable.git。源码中有一个 testClient 可以直接使用哦。

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.

大致是一个递归, 禁用外键 ,清除数据 ,启用外键 。

TruncateATable 清除一张表

标签:也会   oracle   seq   version   代码   外键   程序   关键字   rac   

原文地址:http://www.cnblogs.com/zhuwansu/p/7819092.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!