DROP PROCEDURE IF EXISTS floranet.deliveryDate_get; DELIMITER $$ $$ CREATE DEFINER=`root`@`localhost` PROCEDURE `floranet`.`deliveryDate_get`(vPostalCode VARCHAR(15)) READS SQL DATA BEGIN /** * Returns available dates for this postalCode, in the next seven days. * * @param vPostalCode Delivery address postal code */ DECLARE vCurrentDayOfWeek INT; SET vCurrentDayOfWeek = DAYOFWEEK(NOW()); SELECT DISTINCT nextDay FROM ( SELECT CURDATE() + INTERVAL IF( apc.dayOfWeek >= vCurrentDayOfWeek, apc.dayOfWeek - vCurrentDayOfWeek, 7 - apc.dayOfWeek ) DAY nextDay, NOW() + INTERVAL apc.hoursInAdvance - 12 HOUR minDeliveryTime FROM addressPostCode apc WHERE apc.postCode = vPostalCode HAVING nextDay > minDeliveryTime) sub; END$$ DELIMITER ;