]> git.evergreen-ils.org Git - Evergreen.git/blob - Open-ILS/src/sql/Pg/upgrade/0865.schema.convert-MR-holdable_formats.sql
LP#1842940: Improve Alert
[Evergreen.git] / Open-ILS / src / sql / Pg / upgrade / 0865.schema.convert-MR-holdable_formats.sql
1
2 BEGIN;
3
4 SELECT evergreen.upgrade_deps_block_check('0865', :eg_version);
5
6 -- First, explode the field into constituent parts
7 WITH format_parts_array AS (
8     SELECT  a.id,
9             STRING_TO_ARRAY(a.holdable_formats, '-') AS parts
10       FROM  action.hold_request a
11       WHERE a.hold_type = 'M'
12             AND a.fulfillment_time IS NULL
13 ), format_parts_wide AS (
14     SELECT  id,
15             regexp_split_to_array(parts[1], '') AS item_type,
16             regexp_split_to_array(parts[2], '') AS item_form,
17             parts[3] AS item_lang
18       FROM  format_parts_array
19 ), converted_formats_flat AS (
20     SELECT  id, 
21             CASE WHEN ARRAY_LENGTH(item_type,1) > 0
22                 THEN '"0":[{"_attr":"item_type","_val":"' || ARRAY_TO_STRING(item_type,'"},{"_attr":"item_type","_val":"') || '"}]'
23                 ELSE '"0":""'
24             END AS item_type,
25             CASE WHEN ARRAY_LENGTH(item_form,1) > 0
26                 THEN '"1":[{"_attr":"item_form","_val":"' || ARRAY_TO_STRING(item_form,'"},{"_attr":"item_form","_val":"') || '"}]'
27                 ELSE '"1":""'
28             END AS item_form,
29             CASE WHEN item_lang <> ''
30                 THEN '"2":[{"_attr":"item_lang","_val":"' || item_lang ||'"}]'
31                 ELSE '"2":""'
32             END AS item_lang
33       FROM  format_parts_wide
34 ) UPDATE action.hold_request SET holdable_formats = '{' ||
35         converted_formats_flat.item_type || ',' ||
36         converted_formats_flat.item_form || ',' ||
37         converted_formats_flat.item_lang || '}'
38     FROM converted_formats_flat WHERE converted_formats_flat.id = action.hold_request.id;
39
40 COMMIT;
41