2024-01-15 11:31:03 +00:00
|
|
|
DELIMITER $$
|
2024-08-20 08:06:10 +00:00
|
|
|
CREATE OR REPLACE DEFINER=`vn`@`localhost` FUNCTION `vn`.`itemPacking`(vBarcode VARCHAR(22), vWarehouseFk INT)
|
2024-01-15 11:31:03 +00:00
|
|
|
RETURNS int(11)
|
|
|
|
DETERMINISTIC
|
|
|
|
BEGIN
|
|
|
|
|
|
|
|
DECLARE vPacking INTEGER DEFAULT 0;
|
|
|
|
DECLARE vItemFk INTEGER;
|
|
|
|
|
|
|
|
SELECT vn.barcodeToItem(vBarcode) INTO vItemFk;
|
|
|
|
|
|
|
|
SELECT IFNULL(packing,0) INTO vPacking
|
|
|
|
FROM vn.buy
|
|
|
|
WHERE id = CAST(vBarcode AS DECIMAL(18,0));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
IF NOT vPacking THEN
|
|
|
|
CALL cache.last_buy_refresh(FALSE);
|
|
|
|
SELECT IFNULL(packing,1) INTO vPacking
|
|
|
|
FROM
|
|
|
|
(SELECT packing , created
|
|
|
|
FROM vn.itemShelving
|
|
|
|
WHERE itemFk = vItemFk
|
|
|
|
UNION ALL
|
|
|
|
SELECT b.packing, landing
|
|
|
|
FROM vn.buy b
|
|
|
|
JOIN cache.last_buy lb ON lb.buy_id = b.id
|
|
|
|
WHERE lb.warehouse_id = vWarehouseFk
|
|
|
|
AND b.itemFk = vItemFk
|
|
|
|
) packings
|
|
|
|
ORDER BY created desc
|
|
|
|
LIMIT 1;
|
|
|
|
|
|
|
|
END IF;
|
|
|
|
|
|
|
|
RETURN vPacking;
|
|
|
|
|
|
|
|
END$$
|
|
|
|
DELIMITER ;
|