`

SQL truncate 、delete与drop区别

    博客分类:
  • sql
 
阅读更多

2011-11-25 14:26 by 编程笔记, 32342 阅读, 1 评论, 收藏编辑

相同点:

1.truncate和不带where子句的delete、以及drop都会删除表内的数据。

 

2.drop、truncate都是DDL语句(数据定义语言),执行后会自动提交。

 

不同点:

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,再重新导入/插入数据。


6.delete是DML语句,不会自动提交。drop/truncate都是DDL语句,执行后会自动提交。

 

7、TRUNCATE   TABLE   在功能上与不带   WHERE   子句的   DELETE   语句相同:二者均删除表中的全部行。但   TRUNCATE   TABLE   比   DELETE   速度快,且使用的系统和事务日志资源少。DELETE   语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE   TABLE   通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。 

 

8、TRUNCATE   TABLE   删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用   DELETE。如果要删除表定义及其数据,请使用   DROP   TABLE   语句。  
    
9、对于由   FOREIGN   KEY   约束引用的表,不能使用   TRUNCATE   TABLE,而应使用不带   WHERE   子句的   DELETE   语句。由于   TRUNCATE   TABLE   不记录在日志中,所以它不能激活触发器。    
 

10、TRUNCATE   TABLE   不能用于参与了索引视图的表。  

分享到:
评论

相关推荐

    sql之truncate_、delete与drop区别.pdf

    ### SQL之TRUNCATE、DELETE与DROP的区别 #### 概述 在SQL中,`TRUNCATE`、`DELETE`和`DROP`都是用于管理数据库表的重要命令,但它们之间存在显著的区别。本文将深入探讨这三种命令的功能、用法及其应用场景。 ####...

    sql之truncate、delete与drop区别

    在SQL语言中,`TRUNCATE`、`DELETE` 和 `DROP` 是三个非常重要的数据操作语句,它们各自有着不同的用途和特性。理解这些差异对于数据库管理至关重要,特别是对于数据安全性和性能优化方面。 首先,`TRUNCATE` 语句...

    truncate,delete以及drop区别汇总

    `truncate`, `delete` 和 `drop` 是三种常见的 SQL 命令,它们在功能上有很大的差异。本文将详细探讨这三种命令之间的区别,并通过具体的场景分析来帮助读者更好地理解和使用这些命令。 #### 二、`truncate` 命令...

    数据库中truncate,delete,drop语句的比较

    在数据库管理中,`truncate`、`delete`与`drop`是三种常见的SQL语句,它们各自拥有不同的功能与用途,对于初学者来说,区分这三种语句及其适用场景是非常重要的。 1. **`TRUNCATE`**: - **定义**:`TRUNCATE`是一...

    秒懂drop、truncate和delete的区别

    `DROP`、`TRUNCATE`和`DELETE`是SQL中用于删除数据的三个关键命令,它们各自有不同的特性和应用场景。以下是它们的详细对比和解释: 1. **DELETE语句**: DELETE是一种数据操纵语言(DML),这意味着它涉及到对...

    实例理解SQL中truncate和delete的区别

    本文以一个简单实例为大家介绍了SQL中truncate和delete的区别,帮助大家理解,具体内容如下 ---创建表Table1 IF OBJECT_ID('Table1','U') IS NOT NULL DROP TABLE Table1 GO CREATE TABLE Table1 (ID INT NOT NULL,...

    SQL语句中----删除表数据drop、truncate和delete的用法

    SQL语句中----删除表数据drop、truncate和delete的用法,对你爱不完

    MySQL删除表操作实现(delete、truncate、drop的区别)

    本文主要讲mysql中三种删除表的操作,delete语句、truncate语句以及drop语句的区别: 简介 delete 1、删除整张表的数据: delete from table_name; 2、删除部分数据,添加where子句: delete from table_name ...

    SQL删除语句DROP、TRUNCATE、 DELETE 的区别

    本文将深入探讨三种不同的删除语句:DROP、TRUNCATE和DELETE,它们各自具有特定的用途和特点。 首先,`DROP`语句是最彻底的删除方式,它不仅删除表中的所有数据,还会删除表的结构和定义。这意味着一旦执行`DROP ...

    详解SQL中drop、delete和truncate的异同

    在SQL中,`DROP`、`DELETE`和`TRUNCATE`都是用于处理表中数据的命令,但它们之间存在显著的差异。首先,让我们深入探讨它们的共同点和不同点。 **相同点:** 1. `TRUNCATE`和不带`WHERE`子句的`DELETE`都会删除表中...

    SQL中Truncate的用法

    TRUNCATE TABLE 与没有 WHERE 子句的 DELETE 语句类似;但是,TRUNCATE TABLE 速度更快,使用的系统资源和事务日志资源更少。下面介绍SQL中Truncate的用法 当你不再需要该表时, 用 drop;当你仍要保留该表,但要...

    sqlserver中drop、truncate和delete语句的用法

    在SQL Server中,数据删除操作通常涉及三种不同的语句:DROP、TRUNCATE和DELETE,它们各自有不同的用途和特点。 1. **DROP语句**: DROP主要用于彻底删除数据库对象,如表、视图、存储过程等。在表格上下文中,`...

    drop,truncate与delete的区别

    _drop, truncate 和 delete 是 SQL 语言中三种常用的数据删除命令,但是它们之间有着明显的区别._ _相同点:_ truncate 和不带 where 子句的 delete 语句,以及 drop 都会删除表内的数据。 _不同点:_ 1. _删除...

    JS代码防止SQL注入的方法(超简单)

    var illegalChars = /select|update|delete|truncate|join|union|exec|insert|drop|count|'|"|;|>|<|%/i; return !illegalChars.test(inputValue); } // 给输入框添加事件监听,验证输入并给出反馈 document....

    详解MySQL中DROP,TRUNCATE 和DELETE的区别实现mysql从零开始

    在MySQL数据库管理中,删除数据是一项常见的操作,但有三种不同的方法可以实现这一目标:DROP、TRUNCATE和DELETE。理解它们之间的区别至关重要,因为它们各自具有不同的特性和使用场景。 1. **DROP命令**: - DROP...

    oracle数据库删除数据Delete语句和Truncate语句的使用比较

    与Delete不同,Truncate不会触发触发器,也不生成回滚信息,这意味着操作不可撤销。Truncate的基本语法如下: ```sql TRUNCATE [TABLE] table_name; ``` 你可以选择是否保留数据占用的空间: - `DROP STORAGE`:...

    SQL Server删除表及删除表中数据的方法

    在SQL Server中,管理和...总之,掌握`DROP TABLE`、`DELETE`和`TRUNCATE`在SQL Server中的正确使用方式对于有效管理数据库至关重要。理解它们的区别和适用场景,可以帮助你优化数据库性能,避免潜在的数据丢失风险。

Global site tag (gtag.js) - Google Analytics