mysql/sqlserver如何一秒钟删除千万级别的数据

版权声明:作者:上善若水rs 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。 https://blog.csdn.net/sofeware333/article/details/89683818

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

猜你喜欢

转载自blog.csdn.net/sofeware333/article/details/89683818