pl1_stock_io_ledger_detail-bf-turbo.sql 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. truncate table dbt_list_type1;
  2. truncate table dbt_list_sum;
  3. drop procedure if exists pl1_stock_io_ledger_detail;
  4. DELIMITER //
  5. create procedure pl1_stock_io_ledger_detail( _listToken varchar(21), _sdate varchar(8), _edate varchar(8),
  6. _s1 varchar(32), _e1 varchar(32), _s2 varchar(32), _e2 varchar(32),
  7. _s3 varchar(32), _e3 varchar(32), _s4 varchar(32), _e4 varchar(32),
  8. _where varchar(386), _having varchar(386), _orderby varchar(64),
  9. _branch int, _storage int, _target int)
  10. BEGIN
  11. Declare _sbal_date varchar(8);
  12. Declare _ebal_date varchar(8);
  13. Declare _first_bal decimal(20,4);
  14. Declare _first_bad_bal decimal(20,4);
  15. Declare _first_bal_caption varchar(20);
  16. -- Declare _first_id int;
  17. -- Declare _last_id int;
  18. Declare _line_id int;
  19. Declare _line_badstk_status varchar(64);
  20. Declare _line_in decimal(20,4) default "0.0000";
  21. Declare _line_out decimal(20,4) default "0.0000";
  22. Declare _line_bal decimal(20,4) default "0.0000";
  23. Declare _line_bad_bal decimal(20,4) default "0.0000";
  24. Declare _in_sum decimal(20,4) default "0.0000";
  25. Declare _out_sum decimal(20,4) default "0.0000";
  26. Declare _company_name varchar(64);
  27. Declare _item_code varchar(21);
  28. Declare _item_sub_name varchar(128);
  29. Declare _not_found boolean;
  30. Declare _line_cur cursor for -- c5:badstk_status
  31. select t_id, c5, d2, d3 from dbt_list_type1 where list_token = _listToken
  32. order by order_by asc;
  33. Declare continue handler for
  34. not found set _not_found = true;
  35. if _is_first_date(_sdate) then
  36. set _sbal_date = '19000101';
  37. set _ebal_date = '19000101';
  38. else
  39. set _sbal_date = _sdate;
  40. set _ebal_date = _edate;
  41. end if;
  42. -- insert for first_bal
  43. select ifnull(last_mbal.bal_qty,0) + ifnull(stk_bal.io_qty,0) ,
  44. ifnull(last_mbal.bad_bal_qty,0) + ifnull(stk_bal.bad_io_qty,0) ,'이월재고'
  45. into _first_bal, _first_bad_bal, _first_bal_caption
  46. from
  47. dbr_item as mxv
  48. left join
  49. ( select item_id, bal_qty, bad_bal_qty
  50. from dbr_bal_item
  51. where yyyy_mm = _prev_month(_sdate) and storage_id = _storage
  52. ) as last_mbal
  53. on mxv.id = last_mbal.item_id
  54. left join
  55. ( select stk.item_id, sum(io_qty*stock_status) AS io_qty, sum(io_qty*badstk_status) AS bad_io_qty
  56. from dbr_stock_io as stk
  57. inner join dbr_deal_type as deal on deal.id = stk.deal_type_id
  58. where io_date between _first_date(_sbal_date) and _prev_date(_ebal_date)
  59. and storage_id = _storage
  60. group by stk.item_id
  61. ) as stk_bal
  62. on mxv.id = stk_bal.item_id
  63. where mxv.id = _target;
  64. insert into dbt_list_type1 ( created_on, list_token, c3, d4, d5, order_by)
  65. values ( unix_timestamp(), _listToken, _first_bal_caption, _first_bal, _first_bad_bal, '19000101');
  66. -- insert for stock_io
  67. insert into dbt_list_type1
  68. ( created_on, list_token, c1, c2, c3, c4, c5, d1, d2, d3, order_by)
  69. select unix_timestamp(), _listToken, io_date, deal_code, concat(slip_no,' / ', stk.seq_no )slip_no, company_name, badstk_status,
  70. io_prc, stk.io_qty*cast((stock_status+1)/2 as int), stk.io_qty*cast(-1*(stock_status-1)/2 as int),
  71. concat( io_date, '-', -1*stock_status,'-', slip_no, '-', seq_no)
  72. from dbr_stock_io as stk
  73. inner join dbr_company as cmp on cmp.id = stk.company_id
  74. inner join dbr_deal_type as deal on deal.id = stk.deal_type_id
  75. where io_date between _sdate and _edate and storage_id = _storage and stk.item_id = _target;
  76. -- compute line_bal
  77. set _line_bal = _first_bal;
  78. set _line_bad_bal = _first_bad_bal;
  79. open _line_cur;
  80. loop1: loop
  81. fetch _line_cur into _line_id, _line_badstk_status, _line_in, _line_out;
  82. if _not_found then leave loop1; end if;
  83. set _in_sum = _in_sum + ifnull(_line_in,0);
  84. set _out_sum = _out_sum + ifnull(_line_out,0);
  85. if _line_badstk_status = '0' then
  86. set _line_bal = ifnull(_line_bal,0) + ifnull(_line_in,0) - ifnull(_line_out,0);
  87. else
  88. set _line_bad_bal = ifnull(_line_bad_bal,0) + ifnull(_line_in,0) - ifnull(_line_out,0);
  89. end if;
  90. update dbt_list_type1 set d4 = _line_bal, d5 = _line_bad_bal where t_id = _line_id;
  91. end loop loop1;
  92. close _line_cur;
  93. -- write list_sum
  94. select item_code, concat(item_name,' / ',sub_name ) into _item_code, _item_sub_name from dbr_item where id = _target;
  95. insert into dbt_list_sum
  96. ( created_on, list_token, c1, c2, c3, c4, d1, d2, d3, d4)
  97. values (unix_timestamp(), _listToken, _item_code, _item_sub_name, _sdate, _edate,
  98. _first_bal, _in_sum, _out_sum, _line_bal);
  99. END;
  100. //
  101. DELIMITER ;