注册 登录
编程论坛 SQL Server论坛

sql存储过程把查询的结果赋给一个值应该怎么写?

sw4433 发布于 2010-12-10 23:34, 1340 次点击
create proc proc_test
@year int,--年份
@typeId int,--类型
@money1   varchar(100),
@money2   varchar(100)
as
if exists(select * from consume where datepart(year,ConsumeDate)= @year and datepart(month,ConsumeDate)= 1)
    begin
        --我想把查询的值赋给@money1 ,我知道下面的写法是错的,应该怎么写?
        set @money1 = select sum(consumeMoney) from consume where datepart(year,ConsumeDate)= @year and typeId = @typeId
    end
else
    begin
        set @money1 = 0 --设置如果找不到这个月的收入支出,就设置为0, 这里怎么写?
    end

--下面差不多,只是参数不同
if exists(select * from consume where datepart(year,ConsumeDate)= @year and datepart(month,ConsumeDate)= 2)
    begin
        --下面怎么写
        set @money2 = select sum(consumeMoney) from consume where datepart(year,ConsumeDate)= @year and typeId = @typeId
    end
else
    begin
        set @money2 = 0 -- 设置一个值, 这里怎么写?
    end
--把上面查询的的两个结果合并到一条sql语句输出怎么写?
select @money1 @money2  ?????


2 回复
#2
juejitianya2010-12-17 09:19
       select @money1 =sum(case when datepart(month,ConsumeDate)= 1 then consumeMoney else 0 end),
            @money2 =sum(case when datepart(month,ConsumeDate)= 2 then consumeMoney else 0 end),
            from consume where datepart(year,ConsumeDate)= @year and typeId = @typeId
你是不是需要这个代码?
#3
png2010-12-21 00:31
语法错误不多 -

        --我想把查询的值赋给@money1 ,我知道下面的写法是错的,应该怎么写?
        set @money1 = select sum(consumeMoney) from consume where datepart(year,ConsumeDate)
                        = @year and typeId = @typeId
改成 -

        set @money1 = (
                        select sum(consumeMoney) from consume where datepart(year,ConsumeDate)
                        = @year and typeId = @typeId
                       )

        --把上面查询的的两个结果合并到一条sql语句输出怎么写?  
        select @money1 @money2  ?????

改成 -
        print convert(varchar, @money1) + ',  ' + convert(varchar, @money2)

只是恐怕不能解决你的根本问题. 我猜你需要写成 带返回变量的 存储过程.







[ 本帖最后由 png 于 2010-12-21 00:33 编辑 ]
1