Truncate All Tables Records

博客展示了一个用于截断指定数据库中所有表的存储过程代码。该代码通过游标遍历数据库中所有基表,并执行截断操作。代码包含变量声明、游标操作及执行语句等部分。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值