3 SELECT evergreen.upgrade_deps_block_check('0990', :eg_version);
5 CREATE OR REPLACE FUNCTION rating.copy_count(badge_id INT)
6 RETURNS TABLE (record INT, value NUMERIC) AS $f$
8 badge rating.badge_with_orgs%ROWTYPE;
11 SELECT * INTO badge FROM rating.badge_with_orgs WHERE id = badge_id;
13 PERFORM rating.precalc_bibs_by_copy(badge_id);
15 DELETE FROM precalc_copy_filter_bib_list WHERE id NOT IN (
16 SELECT id FROM precalc_filter_bib_list
18 SELECT id FROM precalc_bibs_by_copy_list
20 ANALYZE precalc_copy_filter_bib_list;
23 SELECT f.id::INT AS bib,
24 COUNT(f.copy)::NUMERIC
25 FROM precalc_copy_filter_bib_list f
26 JOIN asset.copy cp ON (f.copy = cp.id)
27 JOIN asset.call_number cn ON (cn.id = cp.call_number)
28 WHERE cn.owning_lib = ANY (badge.orgs) GROUP BY 1;
31 $f$ LANGUAGE PLPGSQL STRICT;
33 INSERT INTO rating.popularity_parameter (id, name, func, require_percentile) VALUES (16, 'Copy Count', 'rating.copy_count', TRUE);