欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

ORACLE DELETE & TRUNCATE 区别

程序员文章站 2024-02-17 21:32:10
...

用法: delete from tablename; truncate table tablename; 两者 相同点: delete、truncate都能起到清除表数据功能; 两者 不同点: delete语句用于表、视图等;delete可以指定单条数据删除;delete属于DML操纵语言; truncate只能用于表;truncate删除整表

用法:

delete from tablename;

truncate table tablename;

两者相同点:

delete、truncate都能起到清除表数据功能;

两者不同点:

delete语句用于表、视图等;delete可以指定单条数据删除;delete属于DML操纵语言;

truncate只能用于表;truncate删除整表数据;truncate属于DDL定义语言;

也就是说delete删除之后数据可以在回滚,使用rollback;而truncate删除之后数据时不可恢复的。

执行效率:

truncate语句删除效率远高于delete语句。

两者执行原理:

delete:删除一条数据之前首先copy这条数据到撤销段,删除几百几千万条都先要copy到撤销段,有人就问了,删除之前为什么都要copy到撤销段里面,别忘了,delete删除之后还可以再使用rollback恢复的,恢复的数据就要根据日志文件到撤销段里找到再回复。中间多一种copy操作,增加额外的一种安全保证,损失点效率是肯定的;

truncate语句直接进行删除,无须copy到撤销段,效率的提升是显著的,但带来的风险也是存在的,如误删除了数据,该删除数据是不可恢复的因为他是DDL,后台隐式提交事务。用时需谨慎。