1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
|
-- ==============================================================
-- GNUmed database schema change script
--
-- License: GPL v2 or later
-- Author: karsten.hilbert@gmx.net
--
-- ==============================================================
\set ON_ERROR_STOP 1
--set default_transaction_read_only to off;
-- --------------------------------------------------------------
\unset ON_ERROR_STOP
drop index ref.idx_branded_drug_uniq_brand_no_code cascade;
drop index ref.idx_branded_drug_uniq_brand_w_code cascade;
\set ON_ERROR_STOP 1
create unique index idx_branded_drug_uniq_brand_no_code
on ref.branded_drug (description, preparation)
where ref.branded_drug.external_code is NULL;
create unique index idx_branded_drug_uniq_brand_w_code
on ref.branded_drug (description, preparation, external_code, external_code_type)
where ref.branded_drug.external_code is not NULL;
\unset ON_ERROR_STOP
alter table ref.branded_drug drop constraint unique_brand cascade;
\set ON_ERROR_STOP 1
-- --------------------------------------------------------------
\unset ON_ERROR_STOP
drop view ref.v_branded_drugs cascade;
\set ON_ERROR_STOP 1
create view ref.v_branded_drugs as
select
r_bd.pk
as pk_brand,
r_bd.description
as brand,
r_bd.preparation
as preparation,
r_bd.atc_code
as atc,
r_bd.external_code
as external_code,
r_bd.external_code_type
as external_code_type,
r_bd.is_fake
as is_fake_brand,
(select array_agg(r_cs.description || '::' || r_cs.amount || '::' || r_cs.unit || '::' || coalesce(r_cs.atc_code, ''))
from
ref.lnk_substance2brand r_ls2b
inner join ref.consumable_substance r_cs on (r_ls2b.fk_substance = r_cs.pk)
where r_ls2b.fk_brand = r_bd.pk
) as components,
exists (
select 1
from clin.substance_intake c_si
where c_si.fk_drug_component in (
select r_ls2b.pk
from ref.lnk_substance2brand r_ls2b
where r_ls2b.fk_brand = r_bd.pk
)
limit 1
) as is_in_use,
(select array_agg(r_ls2b.pk)
from ref.lnk_substance2brand r_ls2b
where r_ls2b.fk_brand = r_bd.pk
) as pk_components,
(select array_agg(r_ls2b.fk_substance)
from ref.lnk_substance2brand r_ls2b
where r_ls2b.fk_brand = r_bd.pk
) as pk_substances,
r_bd.fk_data_source
as pk_data_source,
r_bd.xmin
as xmin_branded_drug
from
ref.branded_drug r_bd
;
grant select on
ref.v_branded_drugs
to group "gm-doctors";
-- --------------------------------------------------------------
select gm.log_script_insertion('v15-ref-v_branded_drugs.sql', 'Revision: 1.1');
-- ==============================================================
|