DELIMITER $$ CREATE OR REPLACE DEFINER=`root`@`localhost` PROCEDURE `stock`.`buyOut_requestQuantity`( vSelf INT, vRequested INT, vDated DATETIME, OUT vSupplied INT) BEGIN /** * Disassociates out picks after the given date until the demanded quantity is * satisfied. * * @param vSelf The buyOut reference * @param vRequested The requested quantity * @param vDate The starting date for the associated buyLots * @param vSupplied The supplied quantity */ DECLARE vBuyLotFk INT; DECLARE vPickQuantity INT; DECLARE vPickGranted INT; DECLARE vDone BOOL; DECLARE vPicks CURSOR FOR SELECT p.buyLotFk, p.quantity FROM buyLot p JOIN buyLot i ON i.id = p.buyLotFk WHERE p.buyOutFk = vSelf AND i.dated > vDated ORDER BY i.dated DESC; DECLARE CONTINUE HANDLER FOR NOT FOUND SET vDone = TRUE; SET vSupplied = 0; OPEN vPicks; myLoop: LOOP SET vDone = FALSE; FETCH vPicks INTO vBuyLotFk, vPickQuantity; IF vDone THEN LEAVE myLoop; END IF; SET vPickGranted = LEAST(vRequested - vSupplied, vPickQuantity); SET vSupplied = vSupplied + vPickGranted; CALL buyLot_removePick(vBuyLotFk, vSelf, vPickGranted, vPickQuantity); UPDATE buyLot SET isSync = FALSE, available = available + vPickGranted WHERE id = vBuyLotFk; IF vSupplied >= vRequested THEN LEAVE myLoop; END IF; END LOOP; CLOSE vPicks; END$$ DELIMITER ;