Project

General

Profile

1
#!/bin/bash
2
# Creates analytical DB
3
# Usage: self [log=]
4

    
5
selfDir="$(dirname -- "$0")"
6

    
7
. "$selfDir/vegbien_dest"
8

    
9
if test -n "${log=1}"; then # $log defaults to 1
10
    exec >>"$selfDir/../inputs/analytical_db/logs/make_analytical_db.log.sql" 2>&1
11
fi
12

    
13
(set -x; date)
14

    
15
sleep 5 # wait for tnrs.make to acquire the lock if being run right after import
16
"$selfDir/waitself" "$selfDir/../inputs/.TNRS/tnrs/tnrs.make"
17

    
18
mk_table()
19
{
20
    local table="$1"
21
    local public_table="\"$public\".$table"
22
    cat <<EOF
23
-- Create $table
24
TRUNCATE $public_table;
25
INSERT INTO $public_table SELECT * FROM ${public_table}_view;
26
ANALYZE $public_table;
27
EOF
28
}
29

    
30
mk_analytical_table()
31
{
32
    local table="$1"
33
    local public_table="\"$public\".$table" analyt_table="analytical_db.$table"
34
    cat <<EOF
35
$(mk_table "$@")
36

    
37
-- Create $analyt_table view pointing to table in $public
38
DROP VIEW IF EXISTS $analyt_table;
39
CREATE VIEW $analyt_table AS
40
SELECT * FROM $public_table;
41
GRANT SELECT ON TABLE $analyt_table TO bien_read;
42
EOF
43
}
44

    
45
((set -x; "$selfDir/psql_verbose_vegbien") <<EOF
46
GRANT USAGE ON SCHEMA analytical_db TO bien_read;
47
GRANT USAGE ON SCHEMA analytical_db TO public_;
48

    
49
TRUNCATE geoscrub_input;
50
INSERT INTO geoscrub_input SELECT * FROM geoscrub_input_view;
51

    
52
SELECT make_family_higher_plant_group();
53
TRUNCATE threatened_taxonlabel;
54
INSERT INTO threatened_taxonlabel SELECT * FROM threatened_taxonlabel_view;
55

    
56
$(mk_analytical_table taxon_trait)
57
$(mk_analytical_table analytical_stem)
58
$(mk_analytical_table provider_count)
59
GRANT SELECT ON TABLE analytical_db.provider_count TO public_;
60
EOF
61
) || exit
62

    
63
remake=1 "$selfDir"/../run export_
64
#"$selfDir/export_analytical_db"
(40-40/83)