From: Dan Wells Date: Fri, 6 Jun 2014 13:19:58 +0000 (-0400) Subject: Forward port 2.5.5 and 2.6.1 upgrade scripts X-Git-Url: https://old-git.evergreen-ils.org/?a=commitdiff_plain;h=65307dea427c4e006da6035699ee2201e9065cb0;p=evergreen%2Fmasslnc.git Forward port 2.5.5 and 2.6.1 upgrade scripts Signed-off-by: Dan Wells --- diff --git a/Open-ILS/src/sql/Pg/version-upgrade/2.5.4-2.5.5-upgrade-db.sql b/Open-ILS/src/sql/Pg/version-upgrade/2.5.4-2.5.5-upgrade-db.sql new file mode 100644 index 0000000000..6acfedf913 --- /dev/null +++ b/Open-ILS/src/sql/Pg/version-upgrade/2.5.4-2.5.5-upgrade-db.sql @@ -0,0 +1,78 @@ +--Upgrade Script for 2.5.4 to 2.5.5 +\set eg_version '''2.5.5''' +BEGIN; +INSERT INTO config.upgrade_log (version, applied_to) VALUES ('2.5.5', :eg_version); + +SELECT evergreen.upgrade_deps_block_check('0880', :eg_version); + +CREATE OR REPLACE FUNCTION authority.calculate_authority_linking( + rec_id BIGINT, rec_control_set INT, rec_marc_xml XML +) RETURNS SETOF authority.authority_linking AS $func$ +DECLARE + acsaf authority.control_set_authority_field%ROWTYPE; + link TEXT; + aal authority.authority_linking%ROWTYPE; +BEGIN + IF rec_control_set IS NULL THEN + -- No control_set on record? Guess at one + SELECT control_set INTO rec_control_set + FROM authority.control_set_authority_field + WHERE tag IN ( + SELECT UNNEST( + XPATH('//*[starts-with(@tag,"1")]/@tag',rec_marc_xml)::TEXT[] + ) + ) LIMIT 1; + + IF NOT FOUND THEN + RAISE WARNING 'Could not even guess at control set for authority record %', rec_id; + RETURN; + END IF; + END IF; + + aal.source := rec_id; + + FOR acsaf IN + SELECT * FROM authority.control_set_authority_field + WHERE control_set = rec_control_set + AND linking_subfield IS NOT NULL + AND main_entry IS NOT NULL + LOOP + -- Loop over the trailing-number contents of all linking subfields + FOR link IN + SELECT SUBSTRING( x::TEXT, '\d+$' ) + FROM UNNEST( + XPATH( + '//*[@tag="' + || acsaf.tag + || '"]/*[@code="' + || acsaf.linking_subfield + || '"]/text()', + rec_marc_xml + ) + ) x + LOOP + + -- Ignore links that are null, malformed, circular, or point to + -- non-existent authority records. + IF link IS NOT NULL AND link::BIGINT <> rec_id THEN + PERFORM * FROM authority.record_entry WHERE id = link::BIGINT; + IF FOUND THEN + aal.target := link::BIGINT; + aal.field := acsaf.id; + RETURN NEXT aal; + END IF; + END IF; + END LOOP; + END LOOP; +END; +$func$ LANGUAGE PLPGSQL; + + + +SELECT evergreen.upgrade_deps_block_check('0881', :eg_version); + +UPDATE config.org_unit_setting_type + SET description = replace(replace(description,'Original','Physical'),'"ol"','"physical_loc"') + WHERE name = 'opac.org_unit_hiding.depth'; + +COMMIT; diff --git a/Open-ILS/src/sql/Pg/version-upgrade/2.6.0-2.6.1-upgrade-db.sql b/Open-ILS/src/sql/Pg/version-upgrade/2.6.0-2.6.1-upgrade-db.sql new file mode 100644 index 0000000000..b447697404 --- /dev/null +++ b/Open-ILS/src/sql/Pg/version-upgrade/2.6.0-2.6.1-upgrade-db.sql @@ -0,0 +1,78 @@ +--Upgrade Script for 2.6.0 to 2.6.1 +\set eg_version '''2.6.1''' +BEGIN; +INSERT INTO config.upgrade_log (version, applied_to) VALUES ('2.6.1', :eg_version); + +SELECT evergreen.upgrade_deps_block_check('0880', :eg_version); + +CREATE OR REPLACE FUNCTION authority.calculate_authority_linking( + rec_id BIGINT, rec_control_set INT, rec_marc_xml XML +) RETURNS SETOF authority.authority_linking AS $func$ +DECLARE + acsaf authority.control_set_authority_field%ROWTYPE; + link TEXT; + aal authority.authority_linking%ROWTYPE; +BEGIN + IF rec_control_set IS NULL THEN + -- No control_set on record? Guess at one + SELECT control_set INTO rec_control_set + FROM authority.control_set_authority_field + WHERE tag IN ( + SELECT UNNEST( + XPATH('//*[starts-with(@tag,"1")]/@tag',rec_marc_xml)::TEXT[] + ) + ) LIMIT 1; + + IF NOT FOUND THEN + RAISE WARNING 'Could not even guess at control set for authority record %', rec_id; + RETURN; + END IF; + END IF; + + aal.source := rec_id; + + FOR acsaf IN + SELECT * FROM authority.control_set_authority_field + WHERE control_set = rec_control_set + AND linking_subfield IS NOT NULL + AND main_entry IS NOT NULL + LOOP + -- Loop over the trailing-number contents of all linking subfields + FOR link IN + SELECT SUBSTRING( x::TEXT, '\d+$' ) + FROM UNNEST( + XPATH( + '//*[@tag="' + || acsaf.tag + || '"]/*[@code="' + || acsaf.linking_subfield + || '"]/text()', + rec_marc_xml + ) + ) x + LOOP + + -- Ignore links that are null, malformed, circular, or point to + -- non-existent authority records. + IF link IS NOT NULL AND link::BIGINT <> rec_id THEN + PERFORM * FROM authority.record_entry WHERE id = link::BIGINT; + IF FOUND THEN + aal.target := link::BIGINT; + aal.field := acsaf.id; + RETURN NEXT aal; + END IF; + END IF; + END LOOP; + END LOOP; +END; +$func$ LANGUAGE PLPGSQL; + + + +SELECT evergreen.upgrade_deps_block_check('0881', :eg_version); + +UPDATE config.org_unit_setting_type + SET description = replace(replace(description,'Original','Physical'),'"ol"','"physical_loc"') + WHERE name = 'opac.org_unit_hiding.depth'; + +COMMIT;