使用SQL TRUNCATE TABLE语句实现删除数据

数据库 SQL Server
在SQL数据库中,有很多可以删除数据的方法,下面就教您如何使用TRUNCATE TABLE语句实现删除数据的方法,供您参考。

SQL TRUNCATE TABLE语句可以删除SQL数据库中的数据,下面就为您详细介绍如何使用SQL TRUNCATE TABLE语句删除数据。

若要删除表中的所有行,则SQL TRUNCATE TABLE 语句是一种快速、无日志记录的方法。SQL TRUNCATE TABLE 与不含有 WHERE 子句的 DELETE 语句在功能上相同。但是,TRUNCATE TABLE 速度更快,并且使用更少的系统资源和事务日志资源。

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

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

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

当使用行锁执行 DELETE 语句时,将锁定表中各行以便删除。TRUNCATE TABLE 始终锁定表和页,而不是锁定各行。
如无例外,在表中不会留有任何页。

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

与 DELETE 语句相同,使用 TRUNCATE TABLE 清空的表的定义与其索引和其他关联对象一起保留在数据库中。
 

 

 

【编辑推荐】

六种SQL Server删除重复行的方法

SQL Server创建表语句介绍

防止SQL注入漏洞的方法

SQL server服务器版的安装方法

sqlserver sa用户密码问题集锦

责任编辑:段燃 来源: 互联网
相关推荐

2010-09-16 16:17:03

TRUNCATE TA

2010-10-08 16:05:30

MySQL DELET

2010-09-02 11:24:45

SQL删除

2010-09-01 16:55:55

SQL删除连接

2011-05-19 13:19:38

sql数据删除

2010-05-20 09:01:22

MySQL数据库

2010-09-02 10:15:46

SQL删除

2010-09-03 13:21:01

SQL删除

2023-03-16 08:19:45

数据库MySQL

2009-09-14 10:45:33

LINQ删除数据

2023-12-05 15:36:39

数据库SQL

2020-11-17 09:01:09

MySQLDelete数据

2011-08-01 22:41:49

SQL Server数Insert

2011-05-18 15:08:03

mysql删除修改数据

2021-06-22 10:24:22

Statement接口修改数据删除数据

2011-02-21 10:35:00

查询删除数据

2010-10-22 17:22:05

sql server删

2010-11-10 11:42:35

SQL Server2

2010-09-03 11:25:58

SQL删除

2010-09-03 14:14:16

SQL删除
点赞
收藏

51CTO技术栈公众号