]> git.evergreen-ils.org Git - Evergreen.git/blob - Open-ILS/src/sql/Pg/upgrade/0841.schema.redo_config_metabib_field_sequence.sql
LP#1564079 Checkout history skips nonexistent items
[Evergreen.git] / Open-ILS / src / sql / Pg / upgrade / 0841.schema.redo_config_metabib_field_sequence.sql
1 BEGIN;
2
3 -- check whether patch can be applied
4 SELECT evergreen.upgrade_deps_block_check('0841', :eg_version);
5
6 ALTER TABLE config.metabib_field_ts_map DROP CONSTRAINT metabib_field_ts_map_metabib_field_fkey;
7 ALTER TABLE config.metabib_search_alias DROP CONSTRAINT metabib_search_alias_field_fkey;
8 ALTER TABLE config.z3950_index_field_map DROP CONSTRAINT z3950_index_field_map_metabib_field_fkey;
9 ALTER TABLE metabib.browse_entry_def_map DROP CONSTRAINT browse_entry_def_map_def_fkey;
10
11 ALTER TABLE config.metabib_field_ts_map ADD CONSTRAINT metabib_field_ts_map_metabib_field_fkey FOREIGN KEY (metabib_field) REFERENCES config.metabib_field(id) DEFERRABLE INITIALLY DEFERRED;
12 ALTER TABLE config.metabib_search_alias ADD CONSTRAINT metabib_search_alias_field_fkey FOREIGN KEY (field) REFERENCES config.metabib_field(id) DEFERRABLE INITIALLY DEFERRED;
13 ALTER TABLE config.z3950_index_field_map ADD CONSTRAINT z3950_index_field_map_metabib_field_fkey FOREIGN KEY (metabib_field) REFERENCES config.metabib_field(id) DEFERRABLE INITIALLY DEFERRED;
14 ALTER TABLE metabib.browse_entry_def_map ADD CONSTRAINT browse_entry_def_map_def_fkey FOREIGN KEY (def) REFERENCES config.metabib_field(id) DEFERRABLE INITIALLY DEFERRED;
15
16
17 DROP FUNCTION IF EXISTS config.modify_metabib_field(source INT, target INT);
18 CREATE FUNCTION config.modify_metabib_field(v_source INT, target INT) RETURNS INT AS $func$
19 DECLARE
20     f_class TEXT;
21     check_id INT;
22     target_id INT;
23 BEGIN
24     SELECT field_class INTO f_class FROM config.metabib_field WHERE id = v_source;
25     IF NOT FOUND THEN
26         RETURN 0;
27     END IF;
28     IF target IS NULL THEN
29         target_id = v_source + 1000;
30     ELSE
31         target_id = target;
32     END IF;
33     SELECT id FROM config.metabib_field INTO check_id WHERE id = target_id;
34     IF FOUND THEN
35         RAISE NOTICE 'Cannot bump config.metabib_field.id from % to %; the target ID already exists.', v_source, target_id;
36         RETURN 0;
37     END IF;
38     UPDATE config.metabib_field SET id = target_id WHERE id = v_source;
39     EXECUTE ' UPDATE metabib.' || f_class || '_field_entry SET field = ' || target_id || ' WHERE field = ' || v_source;
40     UPDATE config.metabib_field_ts_map SET metabib_field = target_id WHERE metabib_field = v_source;
41     UPDATE config.metabib_field_index_norm_map SET field = target_id WHERE field = v_source;
42     UPDATE search.relevance_adjustment SET field = target_id WHERE field = v_source;
43     UPDATE config.metabib_search_alias SET field = target_id WHERE field = v_source;
44     UPDATE config.z3950_index_field_map SET metabib_field = target_id WHERE metabib_field = v_source;
45     UPDATE metabib.browse_entry_def_map SET def = target_id WHERE def = v_source;
46     RETURN 1;
47 END;
48 $func$ LANGUAGE PLPGSQL;
49
50 SELECT config.modify_metabib_field(id, NULL)
51     FROM config.metabib_field
52     WHERE id > 30;
53
54 SELECT SETVAL('config.metabib_field_id_seq', GREATEST(1000, (SELECT MAX(id) FROM config.metabib_field)));
55
56 COMMIT;