这个存储过程怎么写?

qingwei 2003-03-30 11:13:50
我要给@id0赋值,并且@tablename不能写死

declare @id0 int
declare @tablename varchar(20)
declare @mysql varchar(100)
set @tablename='abc'+'1'
set @mysql='select @id0=id from '+@tablename --这里有错,说@id0没有定义
execute(@mysql)

...全文
4 点赞 收藏 1
写回复
1 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
pengdali 2003-03-30
declare @id0 int
declare @tablename varchar(20)
declare @mysql nvarchar(4000)
set @tablename='abc'+'1'
set @mysql=N'select @id0=id from '+@tablename --这里有错,说@id0没有定义


exec sp_executesql @mysql,N'@id0 int output',@id0 output

select @id0
回复
相关推荐
发帖
疑难问题
创建于2007-09-28

2.1w+

社区成员

MS-SQL Server 疑难问题
申请成为版主
帖子事件
创建了帖子
2003-03-30 11:13
社区公告
暂无公告