sql语句快速清空表
2017-08-15 10:55
148 查看
对于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语句!
注:这个方法虽然很快速,但是一虽删除了数据就不可逆了!
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语句!
注:这个方法虽然很快速,但是一虽删除了数据就不可逆了!
相关文章推荐
- MySQL 最快速清空数据表数据的 SQL 语句
- sql快速清空数据表的语句
- 清空SQL数据库日志|数据库开发|SQL|web开发|快速开发|中间件平台|方正飞鸿|ES2007|
- DataGrid连接Access的快速分页法(2)——SQL语句的选用(升序与降序)
- 在测试sql语句性能时先清空缓存
- 使用SQL语句清空数据库所有表的数据
- MySQl优化千万数据级快速分页sql语句
- 使用SQL语句清空数据库所有表的数据
- SQL语句快速添加表的记录
- 清空某表的全部数据的SQL语句
- DataGrid连接Access的快速分页法——动态生成SQL语句
- 教你快速掌握SQL语句各种写法的效率问题
- 一段用于清空数据库中所有的用户表的SQL语句[原创]
- 如何使用dba_source快速定位sql语句
- 如何快速按自己的编码风格编写sql语句
- pl/sql快速输入select * from等语句
- SQL 快速建表语句
- 清空数据库所有表,所有存储过程SQL语句
- Sql Server中如何快速修正SQL 语句错误
- Mysql最快清空数据库表的SQL语句