函数 | drop | truncate | delete |
---|---|---|---|
分类 | 数据库定义语言(ddl) | 数据库定义语言(ddl) | 数据库操作语言(dml) |
删除内容 | 删除表的结构被依赖的约束(constrain)、触发器(trigger)、索引(index);依赖于该表的存储过程/函数将保留,但是变为 invalid 状态 | 只删除数据不删除表的结构(定义) | 只删除数据不删除表的结构(定义) |
回滚 | 操作立即生效,原数据不放到 rollback segment 中,不能回滚 | 操作立即生效,原数据不放到 rollback segment 中,不能回滚 | 这个操作会放到 rollback segement 中,事务提交之后才生效 |
trigger | 操作不触发 trigger | 操作不触发 trigger | 如果有相应的 trigger,执行的时候将被触发 |
速度 | 快 | 中 | 慢 |
原理 | 删除表定义及其数据 | 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放 | DELETE语句每次删除一行,并在事务日志中为所删除的每行记录一项 |
drop、truncate、delete三者区别
最新推荐文章于 2020-07-05 21:44:37 发布