2024-07-22 09:52:42 +00:00
|
|
|
DELIMITER $$
|
2024-08-20 08:06:10 +00:00
|
|
|
CREATE OR REPLACE DEFINER=`vn`@`localhost` TRIGGER `vn`.`roadmapStop_beforeUpdate`
|
2024-07-22 09:52:42 +00:00
|
|
|
BEFORE UPDATE ON `roadmapStop`
|
|
|
|
FOR EACH ROW
|
|
|
|
BEGIN
|
2025-01-30 14:00:19 +00:00
|
|
|
DECLARE vMaxEta DATETIME;
|
|
|
|
|
2025-01-21 13:03:50 +00:00
|
|
|
SET NEW.editorFk = account.myUser_getId();
|
2025-01-30 14:00:19 +00:00
|
|
|
|
|
|
|
IF NOT (NEW.description <=> OLD.description) THEN
|
|
|
|
SET NEW.description = UCASE(NEW.description);
|
|
|
|
END IF;
|
|
|
|
|
2025-01-22 11:40:58 +00:00
|
|
|
IF (NOT (NEW.roadmapFk <=> OLD.roadmapFk) AND NEW.roadmapFk IS NOT NULL)
|
|
|
|
OR (NOT (NEW.eta <=> OLD.eta) AND NEW.eta IS NOT NULL) THEN
|
|
|
|
|
|
|
|
IF NEW.eta < (SELECT etd FROM roadmap WHERE id = NEW.roadmapFk) THEN
|
|
|
|
CALL util.throw('Departure time can not be after arrival time');
|
|
|
|
END IF;
|
2025-01-30 14:00:19 +00:00
|
|
|
|
|
|
|
SELECT MAX(eta) INTO vMaxEta
|
|
|
|
FROM roadmapStop
|
|
|
|
WHERE roadmapFk = NEW.roadmapFk;
|
|
|
|
|
|
|
|
IF NEW.eta > vMaxEta OR vMaxEta IS NULL THEN
|
|
|
|
UPDATE roadmap
|
|
|
|
SET eta = COALESCE(vMaxEta, NEW.eta)
|
|
|
|
WHERE id = NEW.roadmapFk;
|
|
|
|
END IF;
|
2025-01-22 11:40:58 +00:00
|
|
|
END IF;
|
2024-07-22 09:52:42 +00:00
|
|
|
END$$
|
|
|
|
DELIMITER ;
|