posts - 1180, comments - 162, trackbacks - 1, articles - 5
  博客园 :: 首页 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理

公告

从SqlServer的动态sql中返回值

Posted on 2010-01-29 20:34 linFen 阅读(129) 评论(0) 编辑 收藏

  这是使用动态Sql的人都会碰到这样的问题,需要从动态执行的sql中返回值,下面给一个简单的实现例子。

 

IF EXISTS(SELECT * FROM SYSOBJECTS WHERE NAME = 'ValueFromSql')
   
DROP PROC ValueFromSql
GO
create proc ValueFromSql

 
as begin

declare @value varchar(100)


exec sp_executesql N'select @value=''From Sql'' ',N'@value varchar(100) out ',@value out

print @value


end

执行结果为; From Sql

如果想把sql语句当成变量传入,定义应该如下,注意@sql的类型应该是nvarchar

IF EXISTS(SELECT * FROM SYSOBJECTS WHERE NAME = 'ValueFromSql')
   
DROP PROC ValueFromSql
GO
create proc ValueFromSql

 
as begin

declare @value varchar(100)
declare @sql nvarchar(4000)

set @sql='select @value=''From Sql'' '

exec sp_executesql @sql,N'@value varchar(100) out ',@value out

print @value


end