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 lots * @param vSupplied The supplied quantity */ DECLARE vPickFk INT; DECLARE vLotFk INT; DECLARE vPickQuantity INT; DECLARE vPickGranted INT; DECLARE vDone BOOL; DECLARE vPicks CURSOR FOR SELECT p.id, p.buyFk, p.quantity FROM buyPick p JOIN buyOut o USING(outFk) WHERE o.outFk = vSelf AND o.dated > vDated ORDER BY o.dated DESC; DECLARE CONTINUE HANDLER FOR NOT FOUND SET vDone = TRUE; SET vSupplied = 0; OPEN vPicks; myLoop: LOOP SET vDone = FALSE; FETCH vPicks INTO vPickFk, vLotFk, vPickQuantity; IF vDone THEN LEAVE myLoop; END IF; SET vPickGranted = LEAST(vRequested - vSupplied, vPickQuantity); SET vSupplied = vSupplied + vPickGranted; CALL buyLot_removePick(vPickFk, vPickGranted, vPickQuantity); UPDATE buyLot SET isSync = FALSE, available = available + vPickGranted WHERE buyFk = vLotFk; IF vSupplied >= vRequested THEN LEAVE myLoop; END IF; END LOOP; CLOSE vPicks; END$$ DELIMITER ;