sql server 删除数据库中所有表数据

sql server 删除数据库中所有表数据


1.清空所有数据表中的记录:

exec sp_msforeachtable  @Command1 ='truncate table ?'
 
--------------------------------------------------

2.删除所有数据表


exec sp_msforeachtable 'delete   N''?'''

--------------------------------------------------

3.如果出现 数据表中有各种约束,就不能使用上面的方法来删除数据了,只能使用以下方式:

//创建自定义存储过程
CREATE PROCEDURE sp_DeleteAllData
AS
//前两句首先关闭所有的外检约束和索引器
EXEC sp_MSForEachTable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL'
EXEC sp_MSForEachTable 'ALTER TABLE ? DISABLE TRIGGER ALL'
//然后 再删除所有的表数据
EXEC sp_MSForEachTable 'DELETE FROM ?'
//然后 再重新 恢复启用表约束和索引器。
EXEC sp_MSForEachTable 'ALTER TABLE ? CHECK CONSTRAINT ALL'
EXEC sp_MSForEachTable 'ALTER TABLE ? ENABLE TRIGGER ALL'
EXEC sp_MSFOREACHTABLE 'SELECT * FROM ?'
GO 
 

--------------------------------------------------
sql server 2008 删除数据库中所有表的数据
if exists (select * from sysobjects where type='P' and name=N'P_DeleteAllData' )
    drop procedure P_DeleteAllData
go
CREATE PROCEDURE P_DeleteAllData
as
    EXEC sp_MSforeachtable  'ALTER TABLE ? NOCHECK CONSTRAINT ALL' --禁用约束
    EXEC sp_MSforeachtable  'ALTER TABLE ? DISABLE TRIGGER ALL' --禁用触发器
    EXEC sp_MSforeachtable  'DELETE FROM ?' --删除所有表中的数据
    EXEC sp_MSforeachtable  'ALTER TABLE ? CHECK CONSTRAINT ALL' --启用约束
    EXEC sp_MSforeachtable  'ALTER TABLE ? ENABLE TRIGGER ALL' --启用触发器
go

--------------------------------------------------


 
在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
 
--------------------------------------------------