salix/db/routines/vn/triggers/roadmapStop_beforeUpdate.sql

43 lines
1.1 KiB
MySQL
Raw Normal View History

DELIMITER $$
2024-08-20 08:06:10 +00:00
CREATE OR REPLACE DEFINER=`vn`@`localhost` TRIGGER `vn`.`roadmapStop_beforeUpdate`
BEFORE UPDATE ON `roadmapStop`
FOR EACH ROW
BEGIN
2025-01-30 14:00:19 +00:00
DECLARE vMaxEta DATETIME;
2025-01-31 09:57:44 +00:00
DECLARE vCurrentEta DATETIME;
2025-01-30 14:00:19 +00:00
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)
2025-01-31 13:25:23 +00:00
OR (NOT (NEW.eta <=> OLD.eta)) THEN
2025-01-22 11:40:58 +00:00
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
2025-01-31 09:57:44 +00:00
SELECT MAX(eta) INTO vMaxEta
2025-01-30 14:00:19 +00:00
FROM roadmapStop
2025-01-31 09:57:44 +00:00
WHERE roadmapFk = NEW.roadmapFk
AND id <> OLD.id;
2025-01-30 14:00:19 +00:00
2025-01-31 13:25:23 +00:00
IF vMaxEta < NEW.eta OR vMaxEta IS NULL THEN
2025-01-31 09:57:44 +00:00
SET vMaxEta = NEW.eta;
END IF;
SELECT eta INTO vCurrentEta
FROM roadmap
WHERE id = NEW.roadmapFk;
2025-01-31 13:25:23 +00:00
IF (vMaxEta <> vCurrentEta OR vMaxEta IS NULL) OR vMaxEta IS NOT NULL THEN
2025-01-30 14:00:19 +00:00
UPDATE roadmap
2025-01-31 09:57:44 +00:00
SET eta = vMaxEta
2025-01-30 14:00:19 +00:00
WHERE id = NEW.roadmapFk;
END IF;
2025-01-22 11:40:58 +00:00
END IF;
END$$
DELIMITER ;