drop,truncate,delete 区别
来源:互联网 发布:淘宝号贷款有被骗的吗 编辑:程序博客网 时间:2024/05/01 06:03
使用delete语句删除数据的一般语法格式:
delete [from]
{table_name、view_name}
[where<search_condition>]
将XS表中的所有行数据删除
delete XS
执行完后,发现XS表中的数据都删除了,但是表的结构什么都还在。
truncate
truncate table语句将删除指定表中所有数据,因此也称其为清除表数据语句,一般格式如下
truncate table name
由于truncate语句将删除表中的所有数据,且无法恢复,因此使用时必须十分小心。
使用truncate table删除了指定表中的所有行,但表的结构及其列,约束,索引等保持不变,而新行标识所用的计数值重置为该列的初始值。如果想保留标识计数值,则要使用DELETE语句。
TRUNCATE TABLE执行速度比DELETE块,且使用的系统和事务日志资源少。DELETE语句每次删除一行,并在事务日志中为所删除的每行记录一项。而TRUNCATE TABLE通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
对于有外键约束引用的表,不能使用TRUNCATE TABLE删除数据,而应该使用布袋WHERE子句的DELETE语句。另外TRUNCATE TABLE也不能用于参与了索引视图的表。
1.DELETE
・DML语言
・可以回退
・可以有条件的删除
DELETE FROM 表名
WHERE 条件
2.TRUNCATE TABLE
・DDL语言
・无法回退
・默认所有的表内容都删除
・删除速度比delete快。
TRUNCATE TABLE 表名
TRUNCATE TABLE 不能用于参与了索引视图的表。 相同之处:1.truncate和不带where子句的delete、以及drop都会删除表内的数据。2.drop、truncate都是DDL语句(数据定义语言),执行后会自动提交。 不同之处:1.drop和delete只是删除表的数据(定义),drop语句将删除表的结构、被依赖的约束(constrain)、触发器 (trigger)、索引(index);依赖于该表的存储过程/函数将保留,但是变为invalid状态。2.delete语句是DML语言,这个操作会放在rollback segement中,事物提交后才生效;如果有相应的触发器(trigger),执行的时候将被触发。truncate、drop是DDL语言,操作后即 生效,原数据不会放到rollback中,不能回滚,操作不会触发trigger。3.delete语句不影响表所占用的extent、高水线(high watermark)保持原位置不动。drop语句将表所占用的空间全部释放。truncate语句缺省情况下将空间释放到minextents的 extent,除非使用reuse storage。truncate会将高水线复位(回到最初)。4.效率方面:drop > truncate > delete5.安全性:小心使用drop与truncate,尤其是在 没有备份的时候,想删除部分数据可使用delete需要带上where子句,回滚段要足够大,想删除表可以用drop,想保留表只是想删除表的所有数据、 如果跟事物无关可以使用truncate,如果和事物有关、又或者想触发 trigger,还是用delete,如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入、插入数据。6.delete是DML语句,不会自动提交。drop/truncate都是DDL语句,执行后会自动提交。 drop一般用于删除整体性数据 如表,模式,索引,视图,完整性限制等delete用于删除局部性数据 如表中的某一元组 DROP把表结构都删了DELETE只是把数据清掉 当你不再需要该表时, 用 drop;当你仍要保留该表,但要删除所有记录时, 用 truncate;当你要删除部分记录时(always with a WHERE clause), 用 delete.
效率方面:drop > truncate > delete5
- delete,truncate,drop 区别
- drop truncate delete区别
- truncate delete drop 区别
- truncate、delete、drop区别
- drop delete truncate 区别
- TRUNCATE,DELETE,DROP区别
- drop,truncate,delete区别
- TRUNCATE DELETE DROP区别
- drop,truncate,delete 区别
- delete、truncate、drop区别
- truncate,delete,drop的区别
- Truncate,delete与drop区别
- DELETE/TRUNCATE/DROP的区别
- Truncate drop 和 delete 区别
- Truncate、delete与drop区别
- DELETE、TRUNCATE、DROP区别分析
- drop ,truncate,delete 的区别
- delete、truncate、drop的区别
- 【linux】ubuntu 14.04下安装mysql 5.5
- 用Mathematica拯救一只数字化猫(2)
- SQLite和MySQL数据库的区别与应用
- 分布式MySQL数据库TDSQL架构分析
- 【Maven】maven工程 调试出现 Source not found ,开启jetty调试
- drop,truncate,delete 区别
- MySql数据库分表分区方法
- hdu1281
- MFC中CString的Format方法使用技巧
- iO7以上CIFilter生成二维码(备忘) 此博文包含图片(2015-04-24 14:48:25)转载
- windows内存管理
- WIN32控件使用大全
- [原]GitHub控件之BadgeView(类似QQ消息数字提醒)
- Atomikos数据源配置的三种方法