打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
在sql server数据库中快速删除记录,清空表
在sql server数据库中快速删除记录,清空表
2009-06-12 15:39

在sql server数据库中快速删除记录,清空表

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

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

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

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

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

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

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

 

 

 

在MS SQLSERVER中如何最快的速度清空所有用户表的数据

有时候我们需要清空数据库中所有用户表的数据,如果一张表一张表的清空的话,遇到一个庞大的数据系统估计得崩溃了. 用游标加上用变量来引用表名就可以做到这一点. 用变量来引用表名对表操作可以用在存储过程中,根据需要动太选择引用某个表的数据或对其操作   估计用的不多,好玩而已:)
//定义游标
DECLARE tables_cursor CURSOR
   FOR
   SELECT name FROM sysobjects WHERE type = 'U' //选择用户表名
OPEN tables_cursor //打开游标连接

DECLARE @tablename sysname   // 定义变量
FETCH NEXT FROM tables_cursor INTO @tablename   //结果集中一行一行读取表名
WHILE (@@FETCH_STATUS <> -1) //判断游标状态
BEGIN

   EXEC ('TRUNCATE TABLE ' + @tablename)   //清空表中的数据
   FETCH NEXT FROM tables_cursor INTO @tablename //下一行数据
END

DEALLOCATE tables_cursor //关闭游标
 
例如:
CREATE proc ClearAllUserTable
as
begin
DECLARE tables_cursor CURSOR
   FOR
   SELECT name FROM sysobjects WHERE type = 'U'
OPEN tables_cursor
DECLARE @tablename sysname  
FETCH NEXT FROM tables_cursor INTO @tablename  
WHILE (@@FETCH_STATUS <> -1)
BEGIN
 --print   @tablename
  EXEC ('TRUNCATE TABLE ' + @tablename)  
 
   FETCH NEXT FROM tables_cursor INTO @tablename
END
DEALLOCATE tables_cursor
end;
GO
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
SQL删除所有表数据的实现方法 - 51CTO.COM
使用SQL语句清空数据库所有表的数据
oracle快速清空表中的数据
利用触发器进行数据实时传输的设计与实
【转】数据库游标的概念和作用
SQL Server 2005 查看数据库表的大小 按照表大小排列
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服