SQL 有选择性批量清空整个数据库但保留结构

DECLARE @TruncateSQL VARCHAR(80)
DECLARE @iCount int=0
DECLARE name_cursor cursor for
select 'Truncate Table '+ TABLE_NAME from INFORMATION_SCHEMA.TABLES
WHERE TABLE_NAME NOT IN('System','System2','Operator','OilDef','UserRoll','RollFunction','FunctionType',
'FunctionTType','StationOrgCode','ICCard','ChangeClass','dispensor','Tank')
Open name_cursor
FETCH NEXT FROM name_cursor INTO @TruncateSQL
WHILE @@FETCH_STATUS=0
BEGIN
Exec (@TruncateSQL)
print @TruncateSQL
set @iCount=@iCount+1
FETCH NEXT FROM name_cursor INTO @TruncateSQL
END
CLOSE name_cursor
DEALLOCATE name_cursor
print '共清空表数量' + CAST(@iCount AS VARCHAR)

效果:

posted @   IT情深  阅读(5)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
点击右上角即可分享
微信分享提示