51 lines
1.9 KiB
SQL
51 lines
1.9 KiB
SQL
DELIMITER $$
|
|
CREATE OR REPLACE DEFINER=`vn`@`localhost` PROCEDURE `vn`.`ticket_WeightDeclaration`(vClientFk INT, vDated DATE)
|
|
BEGIN
|
|
|
|
DECLARE vTheorycalWeight DECIMAL(10,2);
|
|
DECLARE vRealWeight DECIMAL(10,2);
|
|
DECLARE vRatio DOUBLE;
|
|
|
|
SELECT IFNULL(sum(tob.description),0) INTO vRealWeight
|
|
FROM vn.ticketObservation tob
|
|
JOIN vn.observationType ot ON ot.id = tob.observationTypeFk
|
|
JOIN vn.ticket t ON t.id = tob.ticketFk
|
|
WHERE ot.description = 'Peso Aduana'
|
|
AND t.clientFk = vClientFk
|
|
AND t.shipped BETWEEN vDated AND util.dayend(vDated);
|
|
|
|
SELECT sum(IF(sv.physicalWeight = 0, sv.weight, sv.physicalWeight)) INTO vTheorycalWeight
|
|
FROM vn.ticket t
|
|
JOIN vn.sale s ON s.ticketFk = t.id
|
|
JOIN vn.saleVolume sv ON sv.saleFk = s.id
|
|
JOIN vn.item i ON i.id = s.itemFk
|
|
JOIN vn.itemCost ic ON ic.itemFk = i.id AND ic.warehouseFk = t.warehouseFk
|
|
WHERE t.clientFk = vClientFk
|
|
AND t.shipped BETWEEN vDated AND util.dayend(vDated);
|
|
|
|
SET vRatio = vRealWeight / vTheorycalWeight;
|
|
|
|
DROP TEMPORARY TABLE IF EXISTS tmp.ticketWeight;
|
|
|
|
CREATE TEMPORARY TABLE tmp.ticketWeight
|
|
ENGINE = MEMORY
|
|
SELECT i.intrastatFk,
|
|
ib.ediBotanic,
|
|
FLOOR(sum(s.quantity)) as quantity,
|
|
CAST(vRatio * SUM(IF(sv.physicalWeight = 0, sv.weight, sv.physicalWeight) ) AS DECIMAL(10,2)) physicalWeight,
|
|
o.code as countryCode,
|
|
vDated as Dated
|
|
FROM vn.ticket t
|
|
JOIN vn.sale s ON s.ticketFk = t.id
|
|
JOIN vn.saleVolume sv ON sv.saleFk = s.id
|
|
JOIN vn.item i ON i.id = s.itemFk
|
|
LEFT JOIN vn.itemBotanicalWithGenus ib ON ib.itemFk = i.id
|
|
LEFT JOIN vn.origin o ON o.id = i.originFk
|
|
WHERE t.clientFk = vClientFk
|
|
AND t.shipped BETWEEN vDated AND util.dayend(vDated)
|
|
GROUP BY ib.ediBotanic, o.code;
|
|
|
|
|
|
END$$
|
|
DELIMITER ;
|