truncate和delete的区别

删除表中数据的方法有delete和truncate,delete可以删除整个表的数据,也可以删除满足条件的一条或多条数据,但truncate只能删除整张表的数据.一般将delete操作称作删除表,truncate操作称作截断表.
对比操作如下:
操作 回滚 高水线 空间 效率
truncate 不能 降低 回收 快
delete 能 不变 不回收 慢

1.回滚
在oracle中删除的数据可以回滚是因为它把原始数据放到了undo表空间
DML语句使用undo表空间,DDL语句不使用undo,delete属于DML语句,而truncate属于DDL语句,另外DDL语句是隐式提交.
2.高水线
所有oracle都有一个容纳数据的上限,称之为high water mark(HWM),HWM通常增长幅度为5个数据块.
delete语句不影响表所占用的数据块,高水线保持原位置不动;truncate语句缺省情况下释放空间,除非使用reuse storage; truncate会将高水线复位.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值