首頁 > 資料庫 > mysql教程 > ORACLE DELETE & TRUNCATE 区别

ORACLE DELETE & TRUNCATE 区别

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-06-07 15:20:32
原創
943 人瀏覽過

用法: 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,后台隐式提交事务。用时需谨慎。

 

 

相關標籤:
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板