sql server使用变量动态命名临时表表名的例子

发布时间:2020-07-25编辑:脚本学堂
分享一例sql代码,实现在sql server中使用变量动态命令临时表的表名,有需要的朋友参考学习下。

本节内容:
使用变量动态命名临时表表名

一,sql server不支持动态命名局部临时表的表名,使用如下的语句,无法创建局部临时表:
 

复制代码 代码示例:
declare @n nvarchar(10),@s nvarchar(100)
set @n = 'temp'
set @s = N'select * into #'+@n+' from mytable'
--print @s
exec sp_executesql @s
 

以上语句不提示错误,但查询#temp表时,提示#temp对象名无效。

二,如果需要动态创建表名,只能用以下两种方法:
方法1、创建全局临时表(用两个#)。
 

复制代码 代码示例:
declare @n nvarchar(10),@s nvarchar(100)
set @n = 'temp'
set @s = N'select * into ##'+@n+' from mytable'
--print @s
exec sp_executesql @s

方法2、创建真正的表(去掉#),一定要小心的创建,小心的删除。
 

复制代码 代码示例:
declare @n nvarchar(10),@s nvarchar(100)
set @n = 'temp'
set @s = N'select * into '+@n+' from mytable'
--print @s
exec sp_executesql @s

说明:
这种方法创建的表,存放在当前的数据库里,而不是像临时表一样存放在tempdb数据库里。