标题:truncate、delete与drop
只看楼主
liulheng
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2010-11-13
 问题点数:0 回复次数:7 
truncate、delete与drop
truncate、delete与drop有什么区别呢?
搜索更多相关主题的帖子: delete drop truncate 
2010-11-13 22:20
aei135
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:12
帖 子:232
专家分:1176
注 册:2009-4-6
得分:0 
drop是删除表的,delete和truncate都用来删除表数据的,表结构依然存在,truncate会删除索引,删除速度也快,delelte不会删除索引,速度也慢些,具体还是在网上搜索下比较好!
2010-11-13 22:31
tangyunzhong
Rank: 5Rank: 5
来 自:广西
等 级:职业侠客
威 望:4
帖 子:97
专家分:364
注 册:2010-7-28
得分:0 
以下是引用liulheng在2010-11-13 22:20:48的发言:

truncate、delete与drop有什么区别呢?
truncate 删除数据时不记录日志,其他都记录日志。
delete 删除数据。
drop 是删除表。
2010-11-14 09:19
juejitianya
Rank: 4
等 级:业余侠客
威 望:3
帖 子:44
专家分:272
注 册:2009-9-11
得分:0 
truncate,delete:两个是删除数据表中的数据的操作,属于DML(数据操纵语言);
drop 是删除表定义的操作,属于DDL(数据库模式定义语言);

而truncate和delete的区别,网上有很多详细的解释,我个人理解是:
truncate是强制删除数据,没有考虑安全性,例如:它会将identity字段初始化为1,不触发触发器等等。容易让数据库进入非安全状态;
delete是安全删除,它在保留数据库当前状态和于其他数据库元素的关联性方面进行了验证和处理。
2010-11-15 09:09
guankan2009
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2010-11-12
得分:0 
一下来源于网络:
相同点 truncate和不带where子句的delete, 以及drop都会删除表内的数据
不同点: 1. truncate和 delete只删除数据不删除表的结构(定义) drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger),索引(index); 依赖于该表的存储过程/函数将保留,但是变为invalid状态.
2.delete语句是dml,这个操作会放到rollback segement中,事务提交之后才生效;如果有相应的trigger,执行的时候将被触发. truncate,drop是ddl, 操作立即生效,原数据不放到rollback segment中,不能回滚. 操作不触发trigger.
3.delete语句不影响表所占用的extent, 高水线(high watermark)保持原位置不动 显然drop语句将表所占用的空间全部释放 truncate 语句缺省情况下见空间释放到 minextents个 extent,除非使用reuse storage; truncate会将高水线复位(回到最开始).
4.速度,一般来说: drop> truncate > delete
5.安全性:小心使用drop 和truncate,尤其没有备份的时候.否则哭都来不及 使用上,想删除部分数据行用delete,注意带上where子句. 回滚段要足够大. 想删除表,当然用drop 想保留表而将所有数据删除. 如果和事务无关,用truncate即可. 如果和事务有关,或者想触发trigger,还是用delete. 如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新

[ 本帖最后由 guankan2009 于 2010-11-17 12:50 编辑 ]

guankan
2010-11-17 12:47
zhanghee
Rank: 2
等 级:论坛游民
威 望:1
帖 子:10
专家分:10
注 册:2010-10-28
得分:0 
truncate删除数据时不会备份   而 delect删除时会有备份  drop是删除数据库和表用的
2010-12-10 21:26
png
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:4
帖 子:126
专家分:880
注 册:2010-10-6
得分:0 
以下也来自网络 - MSDN http://msdn.

Some data manipulation language (DML) operations, such as table truncation, use Sch-M locks ....

另外, drop, truncate, delete 都可以放在事物中回滚 - 至少在SQL2005上如此.

create table Tb (ID int)
insert Tb values (1)
insert Tb values (2)

select * from Tb
begin tran
    drop table Tb
rollback
select * from Tb
go

select * from Tb
begin tran
    truncate table Tb
rollback
select * from Tb
go

select * from Tb
begin tran
    delete  Tb
rollback
select * from Tb
go

--drop table Tb
--go
2010-12-11 00:30
hugeannex
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:6
帖 子:477
专家分:911
注 册:2005-3-20
得分:0 
truncate 删除所有记录,重置表(最明显的是自动id归零)
delete 删除记录,自动id继续
drop 删完整个表(而不是记录)

世事如潮我如水,只叹江湖几人回。
2010-12-11 14:18



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-325689-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.298615 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved