Sql Server中用变量名作为表名的解决方案
发布时间:2018-08-25 01:51:49 所属栏目:电子商务 来源:站长网
导读:最近写procedure,遇到一些问题。其中我觉得关于用变量名作为表名的问题较有价值,写出和大家一起分享。请各位若有好的解决方案一定要不吝赐教。 情景: 如果你在写procedure时要根据特定变量的值动态创建table(表名是全部或部分特定变量的值)。例如: d
最近写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 <完> (编辑:焦作站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |