3 SELECT evergreen.upgrade_deps_block_check('0896', :eg_version);
5 CREATE OR REPLACE FUNCTION asset.acp_location_fixer()
10 IF (TG_OP = 'UPDATE') THEN
11 IF NEW.location = OLD.location AND NEW.call_number = OLD.call_number AND NEW.circ_lib = OLD.circ_lib THEN
15 SELECT INTO new_copy_location acpl.id FROM asset.copy_location acpl JOIN actor.org_unit_ancestors_distance((SELECT owning_lib FROM asset.call_number WHERE id = NEW.call_number)) aouad ON acpl.owning_lib = aouad.id WHERE name = (SELECT name FROM asset.copy_location WHERE id = NEW.location) ORDER BY distance LIMIT 1;
16 IF new_copy_location IS NULL THEN
17 SELECT INTO new_copy_location acpl.id FROM asset.copy_location acpl JOIN actor.org_unit_ancestors_distance(NEW.circ_lib) aouad ON acpl.owning_lib = aouad.id WHERE name = (SELECT name FROM asset.copy_location WHERE id = NEW.location) ORDER BY distance LIMIT 1;
19 IF new_copy_location IS NOT NULL THEN
20 NEW.location = new_copy_location;
26 DROP TRIGGER IF EXISTS acp_location_fixer_trig ON asset.copy;
28 CREATE TRIGGER acp_location_fixer_trig
29 BEFORE INSERT OR UPDATE OF location, call_number, circ_lib ON asset.copy
30 FOR EACH ROW EXECUTE PROCEDURE asset.acp_location_fixer();