`
leon.s.kennedy
  • 浏览: 110414 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

使用 TRUNCATE TABLE 删除所有行

    博客分类:
  • SQL
 
阅读更多

 

若要删除表中的所有行,则 TRUNCATE TABLE 语句是一种快速、有效的方法。TRUNCATE TABLE 与不含 WHERE 子句的 DELETE 语句类似。但是,TRUNCATE TABLE 速度更快,并且使用更少的系统资源和事务日志资源。

与 DELETE 语句相比,TRUNCATE TABLE 具有以下优点:

  • 所用的事务日志空间较少。

    DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一个项。TRUNCATE TABLE 通过释放用于存储表数据的数据页来删除数据,并且在事务日志中只记录页释放。

  • 使用的锁通常较少。

    当使用行锁执行 DELETE 语句时,将锁定表中各行以便删除。TRUNCATE TABLE 始终锁定表和页,而不是锁定各行。

  • 如无例外,在表中不会留有任何页。

    执行 DELETE 语句后,表仍会包含空页。例如,必须至少使用一个排他 (LCK_M_X) 表锁,才能释放堆中的空表。如果执行删除操作时没有使用表锁,表(堆)中将包含许多空页。对于索引,删除操作会留下一些空页,尽管这些页会通过后台清除进程迅速释放。

与 DELETE 语句相同,使用 TRUNCATE TABLE 清空的表的定义与其索引和其他关联对象一起保留在数据库中。如果表中包含标识列,该列的计数器将重置为该列定义的种子值。如果未定义种子,则使用默认值 1。若要保留标识计数器,请使用 DELETE。

http://msdn.microsoft.com/zh-cn/library/ms188249(v=sql.105).aspx

分享到:
评论

相关推荐

    oracle中truncate table后的数据恢复

    在Oracle数据库中,`TRUNCATE TABLE`是一个用于删除表中所有数据的命令,它与`DELETE`语句不同,不记录任何删除操作,并且在大多数情况下执行速度更快。然而,一旦执行`TRUNCATE TABLE`,数据通常无法通过常规的...

    Truncate Table的用法讲解

    `TRUNCATE TABLE` 是 SQL 语言中一种用于删除表中所有数据的命令,但它与 `DELETE` 语句有着显著的区别。这篇文章将深入讲解 `TRUNCATE TABLE` 的使用方法,以及它与 `DELETE` 的对比,同时涵盖权限、适用场景及注意...

    Oracle给用户授权truncatetable的实现方案

    在Oracle数据库管理中,有时需要为特定用户授权执行`TRUNCATE TABLE`操作,以便他们在自己的职责范围内能够清理数据而不影响其他用户。然而,Oracle不支持直接为用户授予针对单个表的`TRUNCATE`权限,而是通常将更...

    PostgreSQL TRUNCATE TABLE

    ` 后,`COMPANY` 表将被清空,所有行都将消失,就像刚刚创建的表一样。 值得注意的是,`TRUNCATE TABLE` 操作不会触发任何触发器(如 `BEFORE DELETE` 或 `AFTER DELETE` 触发器),也不会返回任何行数。此外,由于...

    TRUNCATE与 DELETE区别

    而 DELETE 操作后,即使删除了所有行,表中仍然可能残留空数据页,这可能会导致空间的浪费。对于堆组织的表,如果不使用表锁,DELETE 后的空页可能需要后台进程逐步回收。而对于索引,DELETE 同样会留下空页,但这些...

    Oracle_审计表_sys.aud$_授权给用户Truncate权限.docx

    - **删除存储过程**:当不再需要存储过程时,可以使用`DROP`命令将其删除。 ```sql DROP PROCEDURE PROC_TRUNCATE_AUD; ``` ##### 3. 表空间管理 - **查询占用`SYSTEM`表空间前10名的对象**:为了更好地了解`...

    SQL中Truncate的用法

    本文导读:删除表中的数据的方法有delete,truncate, 其中TRUNCATE TABLE用于删除表中的所有行,而不记录单个行删除操作。TRUNCATE TABLE 与没有 WHERE 子句的 DELETE 语句类似;但是,TRUNCATE TABLE 速度更快,使用...

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

    - 如果没有使用`WHERE`子句,则会删除表中的所有行。 - 可能会触发数据库触发器。 - 操作速度通常慢于`TRUNCATE`,尤其是当涉及到大量数据时。 3. **`DROP`**: - **定义**:`DROP`是一种DDL(数据定义语言)...

    SQLite Truncate Table

    这将删除表 `table_name` 中的所有行,但请注意,这种方法不会重置表中的自增(AUTOINCREMENT)列的值。在 SQLite 中,自增列是一种特殊类型的整数列,它的值会在每次插入新行时自动递增。如果需要清空表并重置自增...

    TRUNCATE 快速删除表中的所有数据

    首先,`TRUNCATE TABLE` 的主要作用是删除表中的所有行,但它并不像 `DELETE` 那样逐行删除并记录每个删除操作。这意味着它在事务日志中占用的空间较少。`DELETE` 会在日志中为每一行删除操作创建记录,这可能导致...

    truncate表恢复

    在数据库管理中,"TRUNCATE"命令是一个用于删除表中所有数据的高效操作,它与"DELETE"命令相似但有所不同。"TRUNCATE"不记录单个行的删除,因此速度更快,同时也不触发与删除操作相关的任何触发器或回滚段。然而,这...

    ORACLE truncate 数据恢复

    在Oracle数据库中,`TRUNCATE TABLE`命令用于删除表中的所有数据,但它与`DELETE`语句有所不同。`TRUNCATE`操作是DDL(Data Definition Language)的一部分,而`DELETE`是DML(Data Manipulation Language)。由于`...

    清空ecshop体验数据的简单方法

    ecshop是一个开源的购物系统,但是为了实现很多功能市面上的源码,都是有演示数据的,下面提供一个简单的方法,一键清空体验数据,而不用删除商品了 TRUNCATE TABLE `ecs_admin_log`; TRUNCATE TABLE `ecs_article`;...

    truncate 功能开发文档1

    `TRUNCATE TABLE`主要用于清空指定表的所有数据,但保留表的结构。此操作在逻辑上类似于`DELETE FROM`,但两者存在显著差异: 1. `TRUNCATE TABLE`执行时实际上撤销并重新创建表,速度远超逐行删除。 2. 该操作返回...

    Access中的trucate语句

    这条命令会将"Article"表中的所有行删除,但不会影响表的结构或任何关联的索引和约束。然而,与真正的TRUNCATE语句相比,使用DELETE语句有其局限性。特别是当表中数据量非常大时,DELETE操作可能会相当耗时,并且会...

    ZenCart常用SQL命令

    与使用`DELETE FROM`语句相比,`TRUNCATE TABLE`在执行效率上更高,因为它不涉及记录删除日志的操作,而是直接释放已分配的空间。 #### 四、总结 通过上述介绍可以看出,在ZenCart的二次开发过程中,合理使用SQL...

    delete from 表名与truncate table 表名区别

    而 `TRUNCATE TABLE` 不支持条件删除,它会删除表中的所有记录,无法进行选择性地保留。 3. 性能差异 在处理大量数据时,`TRUNCATE TABLE` 的执行速度通常比 `DELETE FROM` 快得多。这是因为 `TRUNCATE` 只是一个...

    利用 Oracle 系统触发器防止误删除表操作

    当DBA或其他用户具有足够的权限时,可能会因为输入错误等原因执行`DROP TABLE`或`TRUNCATE TABLE`命令,导致重要的数据表被意外删除或清空。例如,用户原本打算删除名为`A`的表(`DROP TABLE A CASCADE CONSTRAINTS;`...

    MySQL中truncate误操作后的数据恢复案例

    在MySQL数据库管理中,误操作是一个常见的问题,尤其是像`TRUNCATE TABLE`这样的命令,它会立即删除表中的所有数据且无法通过`ROLLBACK`撤销。本案例将详细讲解如何在MySQL中,特别是在Percona Server 5.6.16环境下...

Global site tag (gtag.js) - Google Analytics