]> git.evergreen-ils.org Git - working/Evergreen.git/blob - Open-ILS/src/sql/Pg/example.reporter-extension.sql
adding links to the stat-cat views
[working/Evergreen.git] / Open-ILS / src / sql / Pg / example.reporter-extension.sql
1 BEGIN;
2
3 CREATE OR REPLACE VIEW reporter.classic_current_circ AS
4 SELECT  cl.shortname AS circ_lib,
5         cl.id AS circ_lib_id,
6         circ.xact_start AS xact_start,
7         circ_type.type AS circ_type,
8         cp.id AS copy_id,
9         cp.circ_modifier,
10         ol.shortname AS owning_lib_name,
11         lm.value AS language,
12         lfm.value AS lit_form,
13         ifm.value AS item_form,
14         itm.value AS item_type,
15         sl.name AS shelving_location,
16         p.id AS patron_id,
17         g.name AS profile_group,
18         dem.general_division AS demographic_general_division,
19         circ.id AS id,
20         cn.id AS call_number,
21         cn.label AS call_number_label,
22         call_number_dewey(cn.label) AS dewey,
23         CASE
24                 WHEN call_number_dewey(cn.label) ~  E'^[0-9.]+$'
25                         THEN
26                                 btrim(
27                                         to_char(
28                                                 10 * floor((call_number_dewey(cn.label)::float) / 10), '000'
29                                         )
30                                 )
31                 ELSE NULL
32         END AS dewey_block_tens,
33         CASE
34                 WHEN call_number_dewey(cn.label) ~  E'^[0-9.]+$'
35                         THEN
36                                 btrim(
37                                         to_char(
38                                                 100 * floor((call_number_dewey(cn.label)::float) / 100), '000'
39                                         )
40                                 )
41                 ELSE NULL
42         END AS dewey_block_hundreds,
43         CASE
44                 WHEN call_number_dewey(cn.label) ~  E'^[0-9.]+$'
45                         THEN
46                                 btrim(
47                                         to_char(
48                                                 10 * floor((call_number_dewey(cn.label)::float) / 10), '000'
49                                         )
50                                 )
51                                 || '-' ||
52                                 btrim(
53                                         to_char(
54                                                 10 * floor((call_number_dewey(cn.label)::float) / 10) + 9, '000'
55                                         )
56                                 )
57                 ELSE NULL
58         END AS dewey_range_tens,
59         CASE
60                 WHEN call_number_dewey(cn.label) ~  E'^[0-9.]+$'
61                         THEN
62                                 btrim(
63                                         to_char(
64                                                 100 * floor((call_number_dewey(cn.label)::float) / 100), '000'
65                                         )
66                                 )
67                                 || '-' ||
68                                 btrim(
69                                         to_char(
70                                                 100 * floor((call_number_dewey(cn.label)::float) / 100) + 99, '000'
71                                         )
72                                 )
73                 ELSE NULL
74         END AS dewey_range_hundreds,
75         hl.id AS patron_home_lib,
76         hl.shortname AS patron_home_lib_shortname,
77         paddr.county AS patron_county,
78         paddr.city AS patron_city,
79         paddr.post_code AS patron_zip,
80         sc1.stat_cat_entry AS stat_cat_1,
81         sc2.stat_cat_entry AS stat_cat_2,
82         sce1.value AS stat_cat_1_value,
83         sce2.value AS stat_cat_2_value
84   FROM  action.circulation circ
85         JOIN reporter.circ_type circ_type ON (circ.id = circ_type.id)
86         JOIN asset.copy cp ON (cp.id = circ.target_copy)
87         JOIN asset.copy_location sl ON (cp.location = sl.id)
88         JOIN asset.call_number cn ON (cp.call_number = cn.id)
89         JOIN actor.org_unit ol ON (cn.owning_lib = ol.id)
90         JOIN metabib.rec_descriptor rd ON (rd.record = cn.record)
91         JOIN actor.org_unit cl ON (circ.circ_lib = cl.id)
92         JOIN actor.usr p ON (p.id = circ.usr)
93         JOIN actor.org_unit hl ON (p.home_ou = hl.id)
94         JOIN permission.grp_tree g ON (p.profile = g.id)
95         JOIN reporter.demographic dem ON (dem.id = p.id)
96         JOIN actor.usr_address paddr ON (paddr.id = p.billing_address)
97         LEFT JOIN config.language_map lm ON (rd.item_lang = lm.code)
98         LEFT JOIN config.lit_form_map lfm ON (rd.lit_form = lfm.code)
99         LEFT JOIN config.item_form_map ifm ON (rd.item_form = ifm.code)
100         LEFT JOIN config.item_type_map itm ON (rd.item_type = itm.code)
101         LEFT JOIN asset.stat_cat_entry_copy_map sc1 ON (sc1.owning_copy = cp.id AND sc1.stat_cat = 1)
102         LEFT JOIN asset.stat_cat_entry sce1 ON (sce1.id = sc1.stat_cat_entry)
103         LEFT JOIN asset.stat_cat_entry_copy_map sc2 ON (sc2.owning_copy = cp.id AND sc2.stat_cat = 2)
104         LEFT JOIN asset.stat_cat_entry sce2 ON (sce2.id = sc2.stat_cat_entry);
105
106 CREATE OR REPLACE VIEW reporter.legacy_cat1 AS
107 SELECT  id,
108         owner,
109         value
110   FROM  asset.stat_cat_entry
111   WHERE stat_cat = 1;
112
113 CREATE OR REPLACE VIEW reporter.legacy_cat2 AS
114 SELECT  id,
115         owner,
116         value
117   FROM  asset.stat_cat_entry
118   WHERE stat_cat = 2;
119
120
121 COMMIT;
122