У меня есть триггер, который сохраняет изменения, сделанные в отдельной таблице, когда пользователь редактирует данные. Эти данные записываются на веб-странице под текущими данными в удобочитаемом формате, т. Е.
23/04/09 22:47 Джеймс Смит изменил имя арендатора с «Джордж Хилл» на «Джордж Хиллинг».
Триггер у меня выглядит примерно так - это сокращенная версия.
Два вопроса:
A) Это довольно дорого с точки зрения производительности, и если да, то есть ли лучший подход?
Б) Есть ли более аккуратный способ сделать это без всех IF, используя какой-то цикл, возможно?
DELIMITER //
CREATE TRIGGER repair_history AFTER UPDATE ON repairs
FOR EACH ROW
BEGIN
INSERT INTO repair_edit SET repair_id=NEW.repair_id,
edit_date_time=NEW.edit_date_time, edited_by=NEW.edited_by;
IF OLD.tenant_name != NEW.tenant_name THEN
INSERT INTO repair_history SET edit_id=LAST_INSERT_ID(), field='tenant_name',
former_field_value=OLD.tenant_name, new_field_value=NEW.tenant_name;
END IF;
IF OLD.priority != NEW.priority THEN
INSERT INTO repair_history SET edit_id=LAST_INSERT_ID(), field='priority',
former_field_value=OLD.priority, new_field_value=NEW.priority;
END IF;
IF OLD.property_id != NEW.property_id THEN
INSERT INTO repair_history SET edit_id=LAST_INSERT_ID(), field='property_id',
former_field_value=OLD.property_id, new_field_value=NEW.property_id;
END IF;
IF OLD.type_id != NEW.type_id THEN
INSERT INTO repair_history SET edit_id=LAST_INSERT_ID(), field='type_id',
former_field_value=OLD.type_id, new_field_value=NEW.type_id;
END IF;
END; //
DELIMITER ;