大家好,又见面了,我是你们的朋友全栈君。
对于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语句!
注:这个方法虽然很快速,但是一虽删除了数据就不可逆了!
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/137475.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...