-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathpostgeol_structure_02_functions.sql
165 lines (151 loc) · 6.97 KB
/
postgeol_structure_02_functions.sql
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
-- functions:
-- generate_cross_sections_array:{{{
-- TODO doit être fait en tant que postgres; voir à améliorer ça.
CREATE FUNCTION public.generate_cross_sections_array() RETURNS trigger
LANGUAGE plpythonu
AS $$
#{{{
#{{{
# This function is called from a TRIGGER of
# sections_definition table, without any argument;
# it returns a trigger.
# TRIGGER definition:
# CREATE TRIGGER sections_definition_change
# AFTER INSERT OR UPDATE ON sections_definition
# FOR EACH ROW
# EXECUTE PROCEDURE generate_cross_sections_array();
#
# TODO @#faire le pendant, qui détruise les enregistrements de sections_array quand on supprime un enregistrement de sections_definition
# TODO @#do the symetric, to DELETE records from sections_array when a sections_definition record is DELETEd.
#}}}
from math import sin, cos, pi
import string
sep = "," #"\t" # Separator definition: comma
sepchar = "\'" # Character string separator definition: ', in SQL
# Get parameters defining cross-sections, from the sections_definition table:
#res = plpy.execute("SELECT opid, id, location, srid, ll_corner_x, ll_corner_y, ll_corner_z, azim_ng, interval, num_start, count, length, title FROM sections_definition / *WHERE opid IN (SELECT opid FROM operation_active)* /;") # this line had a C-style comment in the SQL: inserted whitespace, to avoid nested SQL comments conflicts in postgeol_structure.sql script
res = plpy.execute("SELECT opid, id, location, srid, ll_corner_x, ll_corner_y, ll_corner_z, azim_ng, interval, num_start, count, length, title FROM sections_definition;")
sql_insert = "" #We build a sql_insert string which will contain everything necessary, mostly INSERTs.
# First, DELETE existing cross-sections from sections_array table:{{{
sql_insert += "DELETE FROM sections_array WHERE sections_array.opid IN (SELECT opid FROM operation_active) AND sections_array.id IS NOT NULL; "
# No: rather, just remove existing cross-sections having the same id as the one which has just been affected:
#sql_insert +="DELETE FROM sections_array WHERE substr(sections_array.title, 1, " + str(NEW["title"].len) + ") = " + sepchar + NEW["title"] + sepchar + ";"
# => marche pas:
# ERREUR: PL/python : NameError: global name 'NEW' is not defined
# CONTEXTE : fonction PL/ generate_cross_sections_array Python
# =>@# TODO reprendre
#}}}
i = 0
for line in res:
# Result is given as dictionaries tuples:
opid = line["opid"]
id = line["id"]
srid = line["srid"]
location = line["location"]
ll_corner_x = line["ll_corner_x"]
ll_corner_y = line["ll_corner_y"]
ll_corner_z = line["ll_corner_z"]
azim_ng = line["azim_ng"]
interval_ = line["interval"]
num_start = line["num_start"]
count = line["count"]
length = line["length"]
title = line["title"]
#num = 1 # no need, there is an autoincrement in the table
section_nr = num_start # cross-section number
sql_insert += "INSERT INTO sections_array (opid, location, id, title, srid, length, x1, y1, z1, x2, y2, z2) VALUES \n"
for j in range(count):
#out = str(opid) + sep + sepchar + location + sepchar + sep + sepchar + location+'_'+str(section_nr).zfill(3) + sepchar + sep + sepchar + title + " - section # "+str(section_nr) + sepchar + sep + str(srid) + sep
out = str(opid) + sep + sepchar + location + sepchar + sep + sepchar + location+'_'+str(section_nr).zfill(3) + sepchar + sep + sepchar + title + " - section " + location+'_'+str(section_nr).zfill(3) + sepchar + sep + str(srid) + sep
x2 = ll_corner_x+interval_*(j) * cos((90.0-azim_ng)/180*pi)
y2 = ll_corner_y+interval_*(j) * sin((90.0-azim_ng)/180*pi)
x1 = x2 - length * sin((90.0-azim_ng)/180*pi)
y1 = y2 + length * cos((90.0-azim_ng)/180*pi)
z = ll_corner_z
out += str(length) + sep + str(x1) + sep + str(y1) + sep + str(z) + sep + str(x2) + sep + str(y2) + sep + str(z)
sql_insert += "("+out+"),\n"
section_nr += 1
sql_insert = sql_insert[0:len(sql_insert)-2] #pour enlever le dernier ",\n"
sql_insert += ";\n"
i += 1
# Instead of returning the string (like in the standalone python script), let's execute directly the SQL:
res = plpy.execute(sql_insert)
return 'OK'
#}}}
$$;
--\c $USER
--}}}
-- lab_ana_results_sample_id_default_value_num:{{{ -- VERSION À 9 REPLACE
CREATE FUNCTION public.lab_ana_results_sample_id_default_value_num() RETURNS trigger
LANGUAGE 'plpgsql'
AS $$
BEGIN
--UPDATE public.lab_ana_results SET sample_id = lab_sampleid WHERE (sample_id IS NULL OR sample_id = '') AND (lab_sampleid IS NOT NULL OR lab_sampleid <> '');
UPDATE public.lab_ana_results SET sample_id_lab = sample_id;
UPDATE public.lab_ana_results SET sample_id = REPLACE(sample_id, 'STD:', '') WHERE sample_id ILIKE 'STD%';
UPDATE public.lab_ana_results SET value_num =
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(value, 'IS', '-999'),
'NSS', '-999'),
'LNR', '-9999'),
'NA', '-99'),
'<', '-'),
'>', ''),
'Not Received', '-9999'),
'Bag Empty', '-9999'),
'N/L', '-9999')::numeric WHERE value <> 'NULL' AND value IS NOT NULL AND value_num IS NULL;
RETURN NULL;
END;
$$
;
--#}}}
-- isnumeric: {{{
-- A useful function from https://stackoverflow.com/questions/16195986/isnumeric-with-postgresql
CREATE OR REPLACE FUNCTION isnumeric(text) RETURNS BOOLEAN AS $$
DECLARE x NUMERIC;
BEGIN
x = $1::NUMERIC;
RETURN TRUE;
EXCEPTION WHEN others THEN
RETURN FALSE;
END;
$$
STRICT
LANGUAGE plpgsql IMMUTABLE;
--}}}
--NON, DÉFINI PLUS BAS --lab_ana_results_sample_id_default_value_num:{{{
--CREATE FUNCTION public.lab_ana_results_sample_id_default_value_num() RETURNS trigger
-- LANGUAGE plpgsql
-- AS $$
--BEGIN
----UPDATE public.lab_ana_results SET sample_id = lab_sampleid WHERE (sample_id IS NULL OR sample_id = '') AND (lab_sampleid IS NOT NULL OR lab_sampleid <> '');
--UPDATE public.lab_ana_results SET sample_id_lab = sample_id;
--UPDATE public.lab_ana_results SET sample_id = REPLACE(sample_id, 'STD:', '') WHERE sample_id ILIKE 'STD%';
--
--UPDATE public.lab_ana_results SET value_num =
--REPLACE(
--REPLACE(
--REPLACE(
--REPLACE(
--REPLACE(
--REPLACE(
--REPLACE(
--REPLACE(value, 'IS', '-999'),
-- 'NSS', '-999'),
-- 'LNR', '-9999'),
-- 'NA', '-99'),
-- '<', '-'),
-- '>', ''),
-- 'Not Received', '-9999'),
-- 'Bag Empty', '-9999')::numeric WHERE value <> 'NULL' AND value IS NOT NULL AND value_num IS NULL;
--RETURN NULL;
--END;
--$$;
--}}}