前几天在项目中,无意中发现sqlserver某张表中存着5000多万条数据,这些数据都没啥用,想着把它们都删了,于是用了delete from table;结果删了一个钟sql语句还在执行;通过查阅资料,发现用 truncate table tableName删除只需要1秒钟;原来用delete from table操作,数据库会记录删除的日志,如果在执行过程中取消delete操作,则被删除的数据会回滚;而用truncate操作不会记录日志;相当于把表删了再重新建一张相同的表,无法回滚,这也是truncate速度快的原因。注:truncate 只适合当需要删除表 全部数据的情况下使用。
mysql/sqlserver如何一秒钟删除百万级别的数据
最新推荐文章于 2025-11-03 14:31:10 发布
在SQLServer中,使用TRUNCATE TABLE比DELETE FROM更快,因为TRUNCATE不会记录删除日志,相当于重新创建表,无法回滚。适用于清空整表数据。

2120

被折叠的 条评论
为什么被折叠?



