sql语句快速清空表

对于sql清空表有三种清空方式

1.delete------ 是逐行删除速度极慢,不适合大量数据删除
2.truncate---- 删除所有数据,保留表结构,不能撤消还原
3.drop-------- 删除表,数据和表结构一起删除,快速

但是在实践过程中我发现,1,2这两种方法在处理大量数据的时候都比较慢,往往要等待许久才能清空完成。所以我考虑还有没有其他的方法达到清空表的作用呢。后来我从导出表结构中想到了一种方法。

首先对原先表进行删除,然后再重建,不就可以达到清空的作用么,例如下:

[sql]  view plain   copy
  1. SET FOREIGN_KEY_CHECKS=0;  
  2.   
  3. -- ----------------------------  
  4. -- Table structure for medical_list  
  5. -- ----------------------------  
  6. DROP TABLE IF EXISTS `medical_list`;  
  7. CREATE TABLE `medical_list` (  
  8.   `id` bigint(20) NOT NULL,  
  9.   `name` longtext,  
  10.   `county_id` bigint(20) DEFAULT NULL,  
  11.   `street_office_id` bigint(20) DEFAULT NULL,  
  12.   `longitude` double DEFAULT NULL,  
  13.   `latitude` double DEFAULT NULL,  
  14.   `type` char(255) DEFAULT NULL,  
  15.   `parent_id` bigint(20) DEFAULT NULL,  
  16.   `max_popu` int(11) DEFAULT NULL,  
  17.   `popu_list` longtext,  
  18.   `popu` int(11) DEFAULT NULL,  
  19.   `building_id` bigint(20) DEFAULT NULL,  
  20.   `gridx` int(10) DEFAULT NULL,  
  21.   `gridy` int(10) DEFAULT NULL,  
  22.   `lRegionID` int(10) DEFAULT NULL,  
  23.   `RegionID_lon` double DEFAULT NULL,  
  24.   `RegionID_lat` double DEFAULT NULL,  
  25.   PRIMARY KEY (`id`)  
  26. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;  

通过导出sql文件-仅结构,就可以得到以上sql语句。然后通过程序执行sql语句!

注:这个方法虽然很快速,但是一虽删除了数据就不可逆了!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值