服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Sql Server - sqlserver通用的删除服务器上的所有相同后缀的临时表

sqlserver通用的删除服务器上的所有相同后缀的临时表

2019-12-16 14:37MSSQL教程网 Sql Server

因为项目需要,必须使用大量临时表,因此编写批量删除临时表的通用语句

代码如下:


use tempdb 
if object_id('tempdb..#table') is not null drop table tempdb..#table 
select name into tempdb..#table 
from (select * from sysobjects where xtype='U') a where 
a.name like '%test_select' 

declare @table varchar(100),@count int 
select @count=count(name) from tempdb..#table 

while(@count>0) 
begin 
select top 1 @table=name from tempdb..#table 

exec(' 
if object_id('''+@table+''') is not null drop table '+@table+' 
delete from tempdb..#table where name='''+@table+''' 
') 
set @count=@count-1 
end 
drop table tempdb..#table 


建议:尽量不要大量使用临时表,因为使用tempdb库会使系统的负载加大。

延伸 · 阅读

精彩推荐