forked from QGEP/datamodel
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path14_geometry_functions.sql
89 lines (79 loc) · 3.38 KB
/
14_geometry_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
-----------------------------------------------
-----------------------------------------------
-- Synchronize GEOMETRY with bottom_level qgep_od.wastewater_node
-----------------------------------------------
-----------------------------------------------
SELECT set_config('qgep.srid', :SRID::text, false);
DO $DO$
BEGIN
EXECUTE format($TRIGGER$
CREATE OR REPLACE FUNCTION qgep_od.synchronize_level_with_altitude_on_wastewater_node()
RETURNS trigger AS
$BODY$
BEGIN
CASE
WHEN TG_OP = 'INSERT' THEN
NEW.situation_geometry = ST_SetSRID( ST_MakePoint( ST_X(NEW.situation_geometry), ST_Y(NEW.situation_geometry), COALESCE(NEW.bottom_level,'NaN') ), %1$s);
WHEN TG_OP = 'UPDATE' THEN
IF NEW.bottom_level <> OLD.bottom_level OR (NEW.bottom_level IS NULL AND OLD.bottom_level IS NOT NULL) OR (NEW.bottom_level IS NOT NULL AND OLD.bottom_level IS NULL) THEN
NEW.situation_geometry = ST_SetSRID( ST_MakePoint( ST_X(NEW.situation_geometry), ST_Y(NEW.situation_geometry), COALESCE(NEW.bottom_level,'NaN') ), %1$s);
ELSE
IF ST_Z(NEW.situation_geometry) <> ST_Z(OLD.situation_geometry) THEN
NEW.bottom_level = NULLIF(ST_Z(NEW.situation_geometry),'NaN');
END IF;
END IF;
END CASE;
RETURN NEW;
END; $BODY$
LANGUAGE plpgsql VOLATILE;
$TRIGGER$, current_setting('qgep.srid'));
END
$DO$;
DROP TRIGGER IF EXISTS synchronize_level_with_altitude ON qgep_od.wastewater_node;
CREATE TRIGGER synchronize_level_with_altitude
BEFORE INSERT OR UPDATE
ON qgep_od.wastewater_node
FOR EACH ROW
EXECUTE PROCEDURE qgep_od.synchronize_level_with_altitude_on_wastewater_node();
-----------------------------------------------
-----------------------------------------------
-- Synchronize GEOMETRY with level qgep_od.cover
-----------------------------------------------
-----------------------------------------------
SELECT set_config('qgep.srid', :SRID::text, false);
DO $DO$
BEGIN
EXECUTE format($TRIGGER$
CREATE OR REPLACE FUNCTION qgep_od.synchronize_level_with_altitude_on_cover()
RETURNS trigger AS
$BODY$
BEGIN
CASE
WHEN TG_OP = 'INSERT' THEN
NEW.situation_geometry = ST_SetSRID( ST_MakePoint( ST_X(NEW.situation_geometry), ST_Y(NEW.situation_geometry), COALESCE(NEW.level,'NaN') ), %1$s);
WHEN TG_OP = 'UPDATE' THEN
IF NEW.level <> OLD.level OR (NEW.level IS NULL AND OLD.level IS NOT NULL) OR (NEW.level IS NOT NULL AND OLD.level IS NULL) THEN
NEW.situation_geometry = ST_SetSRID( ST_MakePoint( ST_X(NEW.situation_geometry), ST_Y(NEW.situation_geometry), COALESCE(NEW.level,'NaN') ), %1$s);
ELSE
IF ST_Z(NEW.situation_geometry) <> ST_Z(OLD.situation_geometry) THEN
NEW.level = NULLIF(ST_Z(NEW.situation_geometry),'NaN');
END IF;
END IF;
END CASE;
RETURN NEW;
END; $BODY$
LANGUAGE plpgsql VOLATILE;
$TRIGGER$, current_setting('qgep.srid'));
END
$DO$;
DROP TRIGGER IF EXISTS synchronize_level_with_altitude ON qgep_od.cover;
CREATE TRIGGER synchronize_level_with_altitude
BEFORE INSERT OR UPDATE
ON qgep_od.cover
FOR EACH ROW
EXECUTE PROCEDURE qgep_od.synchronize_level_with_altitude_on_cover();
-----------------------------------------------
-----------------------------------------------
-- Synchronize reach and reach_point GEOMETRY with level qgep_od.vw_qgep_reach is implemented in vw_qgep_reach.sql
-----------------------------------------------
-----------------------------------------------