Home  >  Article  >  Database  >  sql中truncate,delete,drop的区别

sql中truncate,delete,drop的区别

WBOY
WBOYOriginal
2016-06-07 17:51:231548browse

这三个命令的相同点truncate和不带where子句的delete, 以及drop都会删除表内的数据,不同点是truncate会清除表数据表置id从1开始,delete就只删除记录,drop可以用来删除表或数据库并且将表所占用的空间全部释放

不同点:
1. truncate和 delete只删除数据不删除表的结构(定义)
drop语句将删除表的结构被依赖的约束(constrain),(trigger),索引(index); 依赖于该表的存储过程/函数将保留,但是变为invalid状态.

 代码如下 复制代码

Truncate是SQL中的一个删除数据表内容的语句,用法是:

  语法   TRUNCATE TABLE name   
   参数   name   

是要截断的表的名称或要删除其全部行的表的名称

Truncate table 表名 速度快,而且效率高,因为:   TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少


2.delete语句是dml,这个操作会放到rollback segement中,事务提交之后才生效;如果有相应的trigger,执行的时候将被触发.
truncate,drop是ddl, 操作立即生效,原数据不放到rollback segment中,不能回滚. 操作不触发trigger.

DELETE 语句
DELETE 语句用于删除表中的行。

语法

 代码如下 复制代码

DELETE FROM 表名称 WHERE 列名称 = 值

"Fred Wilson" 会被删除:

DELETE FROM Person WHERE LastName = 'Wilson'

删除所有行
可以在不删除表的情况下删除所有的行。这意味着表的结构、属性和索引都是完整的:

 代码如下 复制代码

DELETE FROM table_name或者:

DELETE * FROM table_name


3.delete语句不影响表所占用的extent
drop语句将表所占用的空间全部释放
truncate 语句缺省情况下见空间释放到 minextents个 extent,除非使用reuse storage.
4.速度,一般来说: drop> truncate > delete

有时候我们会决定我们需要从中清除一个表格。事实上,如果我们不能这样做的话,那将会是一个很大的问题,因为数据库管理师 (Database Administrator -- DBA) 势必无法对数据库做有效率的管理。还好,SQL 有提供一个 DROP TABLE的语法来让我们清除表格。 DROP TABLE 的语法是:

 代码如下 复制代码

DROP TABLE "表格名"

我们如果要清除在SQL CREATE 中建立的顾客表格,我们就打入:

 代码如下 复制代码
DROP TABLE customer.


5.安全性:小心使用drop 和truncate,尤其没有备份的时候.否则哭都来不及
使用上,想删除部分数据行用delete,注意带上where子句. 回滚段要足够大.
想删除表用drop
想保留表而将所有数据删除. 如果和事务无关,用truncate即可. 如果和事务有关,或者想触发trigger,还是用delete.
如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据。

总结,在使用上面三种命令时最好用delete来代替,其它两个都是非常危险工作,一不小心你的数据库或表可能被删除或清除哦。

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn