Truncate All Tables Records

Create Procedure truncateAllTables
 @dbName nvarchar(512)
As

/*
  It truncates all tables in specified database @dbName.
*/

Declare @sqlString nvarchar(4000);

Set @sqlString = '
Declare @t nvarchar (1024)
Declare tbl_cur cursor for ' + 
'select TABLE_NAME from ' + @dbName + '.' + 'INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE = ' + '''BASE TABLE'' ' +

'OPEN tbl_cur

FETCH NEXT from tbl_cur INTO @t ' +

'WHILE @@FETCH_STATUS = 0
BEGIN
EXEC (' + '''TRUNCATE TABLE ''' + '+''' + @dbName + '''+' + '''.dbo.'' + ' + '@t' + ') ' +
'FETCH NEXT from tbl_cur INTO @t ' +
'END

CLOSE tbl_cur
DEALLOCATE tbl_Cur';

--Print @sqlString;
Exec sp_executesql @sqlString;

GO

转载于:https://www.cnblogs.com/zhangchenliang/archive/2010/02/04/1663688.html

猜你喜欢

转载自blog.csdn.net/weixin_34346099/article/details/93496012
ALL