表的truncate,drop和delte区别

本文深入解析了SQL中三种主要的删除操作:DELETE、TRUNCATE和DROP的区别。详细阐述了它们在日志记录、空间占用、应用范围、运行速度及查询类型上的特性,帮助读者理解何时使用哪种操作更为合适。
摘要由CSDN通过智能技术生成

日志记录

  • delete:删n行,并将删除操作作为事务记录在日志,以便回滚。
  • truncate:删除所有数据,并不将删除操作记录在日志。速度快

表和索引空间占用

  • delete:不会减少表或索引所占用的空间,删除数据。(产生数据碎片)
  • truncate:表和索引所占用的空间会恢复到初始大小,删除数据内容。
  • drop:语句将表所占用的空间全释放掉,删除结构和数据。

应用范围

  • delete:针对table和view;
  • truncate:针对table;由 FOREIGN KEY 约束引用的表,不能使用;
  • drop:针对表、视图、索引,触发器,约束;过程、函数保留(变成invalid状态)

运行速度

  •   drop > truncate > delete

查询类型:

  • delete是DML:手动提交(commit),删除操作记录在redoundo表空间中(内容拷贝到undo,动作记录到redo),可以rollback。操作会被放到 rollback segment中,事务提交后才生效。
  • truncate是DDL:会隐式提交,不能回滚,不会触发触发器。原数据不放到 rollback segment中。
  • drop是DDL:会隐式提交,不能回滚,不会触发触发器。原数据不放到 rollback segment中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值