37 lines
1008 B
SQL
37 lines
1008 B
SQL
DELIMITER $$
|
|
CREATE OR REPLACE DEFINER=`vn`@`localhost` PROCEDURE `vn`.`sale_setProblemRounding`(
|
|
vSelf INT
|
|
)
|
|
BEGIN
|
|
/**
|
|
* Update the rounding problem for a sales line
|
|
* @param vSelf Id sale
|
|
*/
|
|
DECLARE vItemFk INT;
|
|
DECLARE vWarehouseFk INT;
|
|
DECLARE vShipped DATE;
|
|
DECLARE vQuantity INT;
|
|
DECLARE vIsProblemCalcNeeded BOOL;
|
|
|
|
SELECT s.itemFk, t.warehouseFk, t.shipped, s.quantity, ticket_isProblemCalcNeeded(t.id)
|
|
INTO vItemFk, vWarehouseFk, vShipped, vQuantity, vIsProblemCalcNeeded
|
|
FROM sale s
|
|
JOIN ticket t ON t.id = s.ticketFk
|
|
WHERE s.id = vSelf;
|
|
|
|
CALL buy_getUltimate(vItemFk, vWarehouseFk, vShipped);
|
|
|
|
CREATE OR REPLACE TEMPORARY TABLE tmp.sale
|
|
SELECT vSelf saleFk,
|
|
MOD(vQuantity, b.`grouping`) hasProblem,
|
|
vIsProblemCalcNeeded isProblemCalcNeeded
|
|
FROM tmp.buyUltimate bu
|
|
JOIN buy b ON b.id = bu.buyFk
|
|
WHERE bu.itemFk = vItemFk;
|
|
|
|
CALL sale_setProblem('hasRounding');
|
|
|
|
DROP TEMPORARY TABLE tmp.sale;
|
|
DROP TEMPORARY TABLE tmp.buyUltimate;
|
|
END$$
|
|
DELIMITER ; |