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