日期:2014-05-18 浏览次数:20630 次
--生成测试数据
create table TBA(名称 varchar(10),数量 int,时间 varchar(10))
insert into TBA values('a',-2,20071011) 
insert into TBA values('a',-1,20071012) 
insert into TBA values('a',-3,20071013) 
create table TBB(名称 varchar(10),数量 int)
insert into TBB values('a',5) 
--执行查询处理
select
    a.名称,
    case 
       when a.初期-a.数量<b.数量 then -a.数量
       else b.数量-a.初期
    end as 数量
from
    (select t.*,(select isnull(sum(-数量),0) from TBA where 名称=t.名称 and 时间<t.时间) as 初期 from TBA t) a,
    TBB b
where
    a.名称=b.名称 
    and 
    a.初期<b.数量
--输出查询结果
/*
名称         数量          
---------- ----------- 
a          2
a          1
a          2
*/
--删除测试数据
drop table TBA,TBB
------解决方案--------------------
keqi
------解决方案--------------------
mark
------解决方案--------------------
好强呀.
------解决方案--------------------
强啊呀