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

在SQLServer中,使用TRUNCATE TABLE比DELETE FROM更快,因为TRUNCATE不会记录删除日志,相当于重新创建表,无法回滚。适用于清空整表数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值