sql语句快速清空表
程序员文章站
2022-06-23 16:08:03
对于sql清空表有三种清空方式
1.delete------ 是逐行删除速度极慢,不适合大量数据删除
2.truncate---- 删除所有数据,保留表结构,不能撤消还原
3...
对于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语句!
注:这个方法虽然很快速,但是一虽删除了数据就不可逆了!
上一篇: 企业网站SEO优化怎么做好呢?
下一篇: 这才是人生赢家
推荐阅读
-
mssql sqlserver 使用sql脚本 清空所有数据库表数据的方法分享
-
sql 2000清空后让表的id从1开始等数据库操作
-
必须会的SQL语句(二) 创建表、修改表结构、删除表
-
sql语句实现四种九九乘法表
-
SQLServer日志清空语句(sql2000,sql2005,sql2008)
-
Sql学习第一天——SQL 练习题(建表/sql语句)
-
Sql Server函数的操作实例(执行多条语句,返回Select查询后的临时表)
-
oracle用什么SQL语句判断表存不存在
-
Oracle新建用户、角色,授权,建表空间的sql语句
-
SQL Server使用Merge语句当源表数据集为空时,无法进行查询的问题