RDS MySQL中TRUNCATE与DELETE清除数据有什么区别
TRUNCATE与DELETE有如下区别:
1、TRUNCATE属于DDL,不支持Rollback回滚;DELETE属于DML,支持Rollback回滚。
2、TRUNCATE无需要将一条条记录在事务日志中,清理速度很快;DELETE需要将一条条记录在事务日志中,清理速度很慢。
3、TRUNCATE使用会降低表中的High WaterMark(高水位线),使用TRUNCATE清除数据之后,查询速度会大幅提升;DELETE使用则不会降低表中的High WaterMark(高水位线),使用DELETE清除数据之后,查询速度不会提升。
4、TRUNCATE属于整表清理不支持WHERE条件查询;DELETE支持WHERE条件查询。
5、TRUNCATE仅支持清除表;DELETE可以支持清除表数据和视图(View)。
TRUNCATE与DROP命令相似,都属于高危操作,请谨慎使用此命令,建议操作前先做好数据库备份。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。