drop table t_geovindu 
  
create table t_geovindu 
( 
    xid int IDENTITY (1, 1), 
    price money, 
    DebitCredit VARCHAR(2), 
    adate datetime default(getdate()) 
      
) 
  
insert into t_geovindu(DebitCredit,price) values('C',10) 
insert into t_geovindu(DebitCredit,price) values('C',25) 
insert into t_geovindu(DebitCredit,price) values('C',36) 
insert into t_geovindu(DebitCredit,price) values('C',66) 
insert into t_geovindu(DebitCredit,price) values('D',-11) 
insert into t_geovindu(DebitCredit,price) values('C',32) 
insert into t_geovindu(DebitCredit,price) values('D',-50) 
  
  
-- 
select a.xid, a.price, 
 (select sum(price) from t_geovindu b where b.xid <= a.xid) as Balance,DebitCredit   
from t_geovindu a 
  
-- 
select xid, price,  
 (case  when Balance  is null then price else Balance  end ) as Balance  
from
 (select a.xid, (select  sum(price) from t_geovindu b where b.xid < a.xid)  as Balance  , a.price 
from t_geovindu a)  x 
-- 
  
select  sum(price) from t_geovindu b where (b.xid < a.xid) 
  
select a.xid, (select  sum(price) from t_geovindu b where b.xid < a.xid)  as Balance  , a.price 
from t_geovindu a 
  
--- 
create function mysum(@xh int, @price int) returns int
begin
   return (select 
           (case when Balance  is null then @price  else Balance  end) as Balance   
          from ( select  sum(price) as Balance  from t_geovindu where xid < @xh) x) 
end
--- 
select xid, price, dbo.mysum(xid, price)  as Balance  
from t_geovindu 
  
  
  
  
  
  
  
create table vipnoDly 
( 
    VID Int IDENTITY (1, 1) PRIMARY KEY, invoiceno nvarchar(50),indate datetime, vipno nvarchar(50),amount int,dcr nvarchar(20) 
) 
go 
  
SET IDENTITY_INSERT [dbo].vipnoDly ON 
Insert vipnoDly(invoiceno,indate,vipno,amount,dcr) Select invoiceno,indate,vipno,amount,dcr From vipdly AS A Where vipno='654321' order by A.indate 
  
select * from vipnoDly 
  
--SET IDENTITY_INSERT dbo.Tool ON 
  
  
Create Function [dbo].[GetVipNoDlyList] 
( 
    @ID nvarchar(20) 
) 
Returns @Tree Table (VID Int IDENTITY (1, 1), invoiceno nvarchar(50),indate datetime, vipno nvarchar(50),amount int,dcr nvarchar(20)) 
As
Begin
Insert @Tree(invoiceno,indate,vipno,amount,dcr) Select invoiceno,indate,vipno,amount,dcr From vipdly AS A Where vipno=@ID order by A.indate 
Return
End
GO 
  
select * from [dbo].[GetVipNoDlyList] ('geovindu') as a order by indate 
  
---SQL Server聚合函数和子查询迭代求和 
---如果ID不是第一條記錄,會出現第一行統計合計有問題,所以需查詢生成一個新的ID增長記錄 
select a.VID, a.amount, 
 (select sum(amount) from [dbo].[GetVipNoDlyList] ('geovindu') b where b.VID <= a.VID) as Balance   
from [dbo].[GetVipNoDlyList] ('geovindu') a