最近写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
<完>
Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved. 闵涛 E_mail:admin@mintao.net(欢迎提供学习资源)
鄂公网安备 42011102001154号
站长:MinTao ICP备案号:鄂ICP备11006601号-18