日期:2014-05-17  浏览次数:20505 次

SQL 游标问题请教
我用函数写了一个查询可以得到如下结果:
ZA001 ZA002 ZA003 ZA004 ZA005 ZA006 ZA007 ZA008
2012 00 1001 库存现金                       0 10 0 0
2012 09 1001 库存现金                       0 0 0 0
2012 10 1001 库存现金                       0 14 2 0
2012 11 1001 库存现金                       0 9 12 0

如何加入游标,使结果显示为:
ZA001 ZA002 ZA003 ZA004 ZA005 ZA006 ZA007 ZA008
2012 00 1001 库存现金                       0 10 0 10
2012 09 1001 库存现金                       10 0 0 10
2012 10 1001 库存现金                       10 14 2 22
2012 11 1001 库存现金                       22 9 12 19

本行ZA005+ZA006-ZA007 = ZA008
本行ZA008  = 下一行ZA005.
这个游标要怎么写?
------解决方案--------------------

究竟ZA008=ZA005+ZA006-ZA007 还是等于下一行的ZA005呢
------解决方案--------------------
引用:
究竟ZA008=ZA005+ZA006-ZA007 还是等于下一行的ZA005呢


下一行的ZA005 = 上一行ZA008
------解决方案--------------------

游标正常写
同时声明一个变量
存储上一行 AZ008

------解决方案--------------------
我是这样写的
DECLARE @ZA002 char(2),@ZA005 Numeric(16,6),@ZA006 Numeric(16,6),@ZA007 Numeric(16,6),@ZA008 Numeric(16,6)
SELECT @ZA005=ZA005 FROM @ACTZA WHERE ZA002='00'

declare my_cursor cursor for 
select ZA002,ZA005,ZA006,ZA007 from @ACTZA order by ZA002 desc
Open my_cursor 
fetch my_cursor into @ZA002,@ZA005,@ZA006,@ZA007
while @@fetch_status=0 
begin 
SET @ZA008=@ZA005+@ZA006-@ZA007
UPDATE A SET A.ZA008=@ZA008  FROM @ACTZA A WHERE A.ZA002=@ZA002 
fetch my_cursor into @ZA002,@ZA005,@ZA006,@ZA007
end 
close my_cursor 
deallocate my_cursor 
要怎么调整
------解决方案--------------------
DECLARE @ZA002 char(2),@ZA005 Numeric(16,6),@ZA006 Numeric(16,6),@ZA007 Numeric(16,6),@ZA008 Numeric(16,6)
SELECT @ZA005=ZA005 FROM @ACTZA WHERE ZA002='00'
----以下是增加的代码
DECLARE @save08 int
set @save08 = 0
---以上是增加的代码

declare my_cursor cursor for 
select ZA002,ZA005,ZA006,ZA007 from @ACTZA order by ZA002 desc
Open my_cursor 
fetch my_cursor into @ZA002,@ZA005,@ZA006,@ZA007
while @@fetch_status=0 
begin 
---修改
SET @ZA008=@save08+@ZA005+@ZA006-@ZA007
UPDATE A SET A.ZA008=@ZA008  FROM @ACTZA A WHERE A.ZA002=@ZA002