频道栏目
首页 > 资讯 > SQL Server > 正文

sql语句快速清空表

17-08-15        来源:[db:作者]  
收藏   我要投稿

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

1.delete------ 是逐行删除速度极慢,不适合大量数据删除

2.truncate---- 删除所有数据,保留表结构,不能撤消还原

3.drop-------- 删除表,数据和表结构一起删除,快速

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

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

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------
-- Table structure for medical_list
-- ----------------------------
DROP TABLE IF EXISTS `medical_list`;
CREATE TABLE `medical_list` (
  `id` bigint(20) NOT NULL,
  `name` longtext,
  `county_id` bigint(20) DEFAULT NULL,
  `street_office_id` bigint(20) DEFAULT NULL,
  `longitude` double DEFAULT NULL,
  `latitude` double DEFAULT NULL,
  `type` char(255) DEFAULT NULL,
  `parent_id` bigint(20) DEFAULT NULL,
  `max_popu` int(11) DEFAULT NULL,
  `popu_list` longtext,
  `popu` int(11) DEFAULT NULL,
  `building_id` bigint(20) DEFAULT NULL,
  `gridx` int(10) DEFAULT NULL,
  `gridy` int(10) DEFAULT NULL,
  `lRegionID` int(10) DEFAULT NULL,
  `RegionID_lon` double DEFAULT NULL,
  `RegionID_lat` double DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

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

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

相关TAG标签
上一篇:git版本库拆分
下一篇:Mybatis代码生成器(Mybatis-plus)
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站