File: v15-ref-v_branded_drugs.sql

package info (click to toggle)
gnumed-server 22.31-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 46,268 kB
  • sloc: sql: 1,217,633; python: 15,878; sh: 1,590; makefile: 20
file content (98 lines) | stat: -rw-r--r-- 2,571 bytes parent folder | download | duplicates (7)
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');

-- ==============================================================