标题:sql存储过程把查询的结果赋给一个值应该怎么写?
只看楼主
sw4433
Rank: 1
等 级:新手上路
帖 子:65
专家分:0
注 册:2009-5-24
结帖率:44.44%
已结贴  问题点数:40 回复次数:2 
sql存储过程把查询的结果赋给一个值应该怎么写?
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  ?????


搜索更多相关主题的帖子: sql 结果 查询 
2010-12-10 23:34
juejitianya
Rank: 4
等 级:业余侠客
威 望:3
帖 子:44
专家分:272
注 册:2009-9-11
得分:20 
       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
你是不是需要这个代码?
2010-12-17 09:19
png
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:4
帖 子:126
专家分:880
注 册:2010-10-6
得分:20 
语法错误不多 -

        --我想把查询的值赋给@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 编辑 ]
2010-12-21 00:31



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-328668-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.440233 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved