Sql Server中用变量名作为表名的解决方案

最近写 procedure ,遇到一些问题。其中我觉得关于“用变量名作为表名”的问题较有价值,写出和大家一起分享。请各位若有好的解决方案一定要不吝赐教。

情景:

如果你在写 procedure 时要根据特定变量的值动态创建 table (表名是全部或部分特定变量的值)。例如:

declare @tablename char(10)

//if some statement

set @tablename='test'

你想用变量 @tablename 的值作为表名创建一个新表 ,那么用 create table @tablename (test char(8)) 语句在 SQL server 2k 中执行就会遇到问题,

解决 ( 接上例 ) :

// 如果表不存在则创建

IF not EXISTS (SELECT name FROM sysobjects

WHERE name =@tablename AND type = 'U')

begin

set @createtable='create table '+ @tablename+' (myname char(2))'

exec(@createtable)

end

<完>

Published At
Categories with 数据库类
Tagged with
comments powered by Disqus