为什么delete 可以回滚 truncate不可以_在Oracle中,比较drop、delete和truncate的区别与联系...

f21b89a06208d149e1227caaca2c6024.png

比较drop、delete、truncate

一:删除内容:

delete是DML语句,可以选择删除部分数据,也可以删除全部数据。

drop是DDL语句,删除表结构及所有数据,同时删除表的结构所依赖的约束,触发器,索引。

truncate也是DDL语句,删除的是表中全部的数据,不能选择删除部分数据,不删除表结构。

二:回滚:

delete删除的数据可以回滚,drop和truncate无法回滚。

三:释放空间:

drop和truncate会释放空间,delete删除不会。

四:执行速度:

一般来说: drop> truncate > delete。

五:安全性:

小心使用drop 和truncate,尤其没有备份的时候.否则哭都来不及。

六:相同点:

drop,truncate都是DDL语句,执行后会自动提交。

truncate和不带where子句的delete, 以及drop都会删除表内的数据。

bd0f09eb73b9a8e897c000a81ded8a20.png
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值