打印本文 打印本文 关闭窗口 关闭窗口
Sql Server中用变量名作为表名的解决方案
作者:武汉SEO闵涛  文章来源:敏韬网  点击数1440  更新时间:2007/11/14 13:00:11  文章录入:mintao  责任编辑:mintao

最近写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


<完>

打印本文 打印本文 关闭窗口 关闭窗口