f_rst_item_bbala.srf 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. $PBExportHeader$f_rst_item_bbala.srf
  2. global type f_rst_item_bbala from function_object
  3. end type
  4. forward prototypes
  5. global function decimal f_rst_item_bbala (long arg_accsetid, long arg_cmonth, string arg_subid, long arg_itemid)
  6. end prototypes
  7. global function decimal f_rst_item_bbala (long arg_accsetid, long arg_cmonth, string arg_subid, long arg_itemid);//返回项目总帐期初数
  8. decimal rst_item_bbala
  9. decimal init_item_bala,cur_item_bala
  10. SELECT isnull(sum(uv_dept_bala.credit),0) - isnull(sum(uv_dept_bala.debit),0)
  11. into :cur_item_bala
  12. FROM uv_dept_bala
  13. WHERE ( uv_dept_bala.accsetid = :arg_accsetid ) AND
  14. ( uv_dept_bala.cmonth < :arg_cmonth ) AND
  15. ( uv_dept_bala.subid = :arg_subid ) and
  16. ( uv_dept_bala.itemid = :arg_itemid )
  17. GROUP BY uv_dept_bala.cmonth,
  18. uv_dept_bala.subid,
  19. uv_dept_bala.itemid ;
  20. SELECT isnull(uv_item_init.balance,0)
  21. into :init_item_bala
  22. FROM uv_item_init
  23. WHERE ( uv_item_init.accsetid = :arg_accsetid ) AND
  24. ( uv_item_init.subid = :arg_subid ) and
  25. ( uv_item_init.itemid = :arg_itemid ) ;
  26. if isnull(cur_item_bala) then cur_item_bala=0
  27. if isnull(init_item_bala) then init_item_bala=0
  28. rst_item_bbala=cur_item_bala + init_item_bala
  29. return rst_item_bbala
  30. end function