1
|
#!/bin/bash
|
2
|
# Creates analytical DB
|
3
|
|
4
|
selfDir="$(dirname -- "$0")"
|
5
|
|
6
|
. "$selfDir/vegbien_dest"
|
7
|
|
8
|
exec 2>>"$selfDir/../inputs/analytical_db/logs/make_analytical_db.log.sql" >&2
|
9
|
|
10
|
(set -x; date)
|
11
|
|
12
|
mk_analytical_table ()
|
13
|
{
|
14
|
local table="$1"
|
15
|
local public_table="\"$public\".$table" analyt_table="analytical_db.$table"
|
16
|
cat <<EOF
|
17
|
-- Create $table
|
18
|
TRUNCATE $public_table;
|
19
|
INSERT INTO $public_table SELECT * FROM ${public_table}_view;
|
20
|
|
21
|
-- Create $analyt_table view pointing to table in $public
|
22
|
DROP VIEW IF EXISTS $analyt_table;
|
23
|
CREATE VIEW $analyt_table AS
|
24
|
SELECT * FROM $public_table;
|
25
|
GRANT SELECT ON TABLE $analyt_table TO bien_read;
|
26
|
GRANT SELECT ON TABLE $analyt_table TO public_;
|
27
|
-- actual access depends on underlying table's permissions
|
28
|
EOF
|
29
|
}
|
30
|
|
31
|
(set -x; "$selfDir/psql_verbose_vegbien") <<EOF
|
32
|
GRANT USAGE ON SCHEMA analytical_db TO bien_read;
|
33
|
GRANT USAGE ON SCHEMA analytical_db TO public_;
|
34
|
|
35
|
TRUNCATE geoscrub_input;
|
36
|
INSERT INTO geoscrub_input SELECT * FROM geoscrub_input_view;
|
37
|
|
38
|
SELECT make_family_higher_plant_group();
|
39
|
TRUNCATE threatened_taxonlabel;
|
40
|
INSERT INTO threatened_taxonlabel SELECT * FROM threatened_taxonlabel_view;
|
41
|
|
42
|
$(mk_analytical_table taxon_trait)
|
43
|
$(mk_analytical_table analytical_stem)
|
44
|
$(mk_analytical_table provider_count)
|
45
|
$(mk_analytical_table analytical_aggregate)
|
46
|
EOF
|
47
|
|
48
|
"$selfDir/export_analytical_db"
|