日期:2014-05-18  浏览次数:20430 次

菜鸟问题,求解...
SQL code

    declare @date varchar(10)
    declare @month int
    declare @year int
    set  @month=datepart(mm,getdate())
    set  @year=datepart(yy,getdate())

    
    exec('select distinct convert(varchar(10),logindate,120) 
    from dbo.BoxLogMonth'+@year+@month+'
    where datediff(dd,logindate,getdate())=1')



代码中定义个3个变量,其中@date这个变量需要通过查询得出,就是下面这个exec里面的语句,我要如何把这个查询出来的结果赋给@date呢?

------解决方案--------------------
output 参数
------解决方案--------------------
SQL code
declare @num int, @sqls nvarchar(4000) 
set @sqls='select count(*) from tableName' 
exec(@sqls) 

--如何将exec执行结果放入变量中? 

declare @num int, @sqls nvarchar(4000) 
set @sqls='select @a=count(*) from tableName ' 
exec sp_executesql @sqls,N'@a int output',@num output 
select @num