delete和truncate的区别

delete 与 truncate 区别:

1)truncate 是DDL语句,delete 是DML语句;

2)truncate 速度远快于 delete;

      原因是:当我们执行delete操作时所有表数据先被copy到回滚表空间,数据量不同花费时间长短不一。而truncate是直接删除数据不进回滚表空间,这也就导致了delete数据后我们可以运行rollback进行数据回滚,而truncate则是永久删除不能回滚;

3)truncate 操作不会触发表上的delete触发器,而delete会正常触发;

4)truncate语句不能带where条件意味着只能全部数据删除,而delete可删除部分数据;

5)truncate 操作会重置表的高水位线(High Water Mark),而delete不会。

原文地址:https://www.cnblogs.com/zhongjiajie/p/5666824.html