更新时间:2022-08-05 来源:黑马程序员 浏览量:
1、删除内容:drop操作会删除表结构、依赖的约束、索引以及触发器,并且会将依赖该表的所有存储过程和视图设置为invalid;而truncate和delete则是只会删除表中的数据,并不会删除表结构。因此如果该表以后不再需要的话可以使用drop,而如果后续还需要的话可以通过truncate或delete,因为这样可以不需要再重新建立表。
2、删除空间:delete操作并不会更改所占用的区的空间,高水位线不会发生改变。drop操作就会直接删除整个表空间,而执行truncate则是相对于先执行drop操作,然后在执行create操作,执行完成后会恢复初始的表空间。
3、语句类型:delete 语句是DML语句,这个操作会放到 rollback segement
中,事务提交之后才生效;并且可以执行对应的触发器。但truncate、drop是DDL操作,会包含implicit
commit,因此不能回滚,也不能不触发触发器。
4、效率:从第二点的描述中可以推断truncate的执行效率要低于drop操作;而delete操作则是按照行记录一行一行的进行删除,因此其效率更低。
5、安全性:使用 drop 和 truncate会导致整个表中的数据都被删除,需格外注意。如果仅想删除部分数据可用delete,但是需要注意where子句得到的范围,会占用rollback segement。
【AI设计】北京143期毕业仅36天,全员拿下高薪offer!黑马AI设计连续6期100%高薪就业
2025-09-19【跨境电商运营】深圳跨境电商运营毕业22个工作日,就业率91%+,最高薪资达13500元
2025-09-19【AI运维】郑州运维1期就业班,毕业14个工作日,班级93%同学已拿到Offer, 一线均薪资 1W+
2025-09-19【AI鸿蒙开发】上海校区AI鸿蒙开发4期5期,距离毕业21天,就业率91%,平均薪资14046元
2025-09-19【AI大模型开发-Python】毕业33个工作日,就业率已达到94.55%,班均薪资20763元
2025-09-19【AI智能应用开发-Java】毕业5个工作日就业率98.18%,最高薪资 17.5k*13薪,全班平均薪资9244元
2025-09-19