MySQL delete/truncate/drop的差别分析
来源:互联网 发布:vb打开资源管理器 编辑:程序博客网 时间:2024/05/16 05:29
用户想要删除数据表可以使用delete、truncate以及drop来删除数据。从功能上讲不带where子句的delete、truncate和drop是相似的。
三者之间的不同之处主要包括以下几点:
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。
0 1
- MySQL delete/truncate/drop的差别分析
- MySQL delete/truncate/drop的差别分析
- MySql的Delete、Truncate、Drop分析
- MySql的Delete、Truncate、Drop分析
- mysql delete,truncate与drop的区别
- mysql truncate,drop,delete的区别
- MySQL 中 truncate、delete、drop 的区别
- Mysql中Drop,Truncate,Delete的区别
- DELETE、TRUNCATE、DROP区别分析
- mysql----drop,truncate.delete区别
- truncate,delete,drop的比较
- truncate,delete,drop的区别
- Truncate,Delete,Drop的比较
- DELETE/TRUNCATE/DROP的区别
- truncate,delete,drop的比较.
- drop ,truncate,delete 的区别
- truncate、drop、delete的异同
- delete、truncate、drop的区别
- Leetcode-357- Count Numbers with Unique Digits C#
- Android 开发技巧-Listview通用适配器BaseCommAdapter
- Java 中 Number那些事
- ibatis如何返回存储过程中的输出参数
- 开放平台-web实现QQ第三方登录
- MySQL delete/truncate/drop的差别分析
- Java 集合类详解(含类图)
- JS预解析,作用域
- [知其然不知其所以然-30] How to work around when system can not be woken up
- Android 4.4 NotificationManagerService使用详解与原理分析(二)__原理分析
- java回调机制
- java类和对象的思想以及常见类使用实例
- 跑马灯动画点击事件
- MATLAB mex时 出现错误“error LNK2019 无法链接的外部符号”