Mercurial > dive4elements > river
comparison flys-backend/doc/schema/postgresql.sql @ 3689:c938e568c4a2 2.9
merged flys-backend/2.9
author | Thomas Arendsen Hein <thomas@intevation.de> |
---|---|
date | Fri, 28 Sep 2012 12:14:44 +0200 |
parents | 3442304b430a |
children | 61195d14b844 |
comparison
equal
deleted
inserted
replaced
3651:06a65baae494 | 3689:c938e568c4a2 |
---|---|
1 BEGIN; | |
2 | |
3 CREATE SEQUENCE UNITS_ID_SEQ; | |
4 | |
5 CREATE TABLE units ( | |
6 id int PRIMARY KEY NOT NULL, | |
7 name VARCHAR(32) NOT NULL UNIQUE | |
8 ); | |
9 | |
10 -- Gewaesser | |
11 CREATE SEQUENCE RIVERS_ID_SEQ; | |
12 | |
13 CREATE TABLE rivers ( | |
14 id int PRIMARY KEY NOT NULL, | |
15 name VARCHAR(256) NOT NULL UNIQUE, | |
16 km_up BOOLEAN NOT NULL DEFAULT true, | |
17 wst_unit_id int NOT NULL REFERENCES units(id) | |
18 ); | |
19 | |
20 -- Bruecke, Haefen, etc. | |
21 CREATE SEQUENCE ATTRIBUTES_ID_SEQ; | |
22 | |
23 CREATE TABLE attributes ( | |
24 id int PRIMARY KEY NOT NULL, | |
25 value VARCHAR(256) NOT NULL UNIQUE | |
26 ); | |
27 | |
28 -- segments from/to at a river | |
29 CREATE SEQUENCE RANGES_ID_SEQ; | |
30 | |
31 CREATE TABLE ranges ( | |
32 id int PRIMARY KEY NOT NULL, | |
33 river_id int NOT NULL REFERENCES rivers(id), | |
34 a NUMERIC NOT NULL, | |
35 b NUMERIC, | |
36 UNIQUE (river_id, a, b) | |
37 ); | |
38 | |
39 -- Lage 'links', 'rechts', etc. | |
40 CREATE SEQUENCE POSITIONS_ID_SEQ; | |
41 | |
42 CREATE TABLE positions ( | |
43 id int PRIMARY KEY NOT NULL, | |
44 value VARCHAR(256) NOT NULL UNIQUE | |
45 ); | |
46 | |
47 -- Kante 'oben', 'unten' | |
48 CREATE SEQUENCE EDGES_ID_SEQ; | |
49 | |
50 CREATE TABLE edges ( | |
51 id int PRIMARY KEY NOT NULL, | |
52 top NUMERIC, | |
53 bottom NUMERIC | |
54 ); | |
55 | |
56 -- Types of annotatations (Hafen, Bruecke, Zufluss, ...) | |
57 CREATE SEQUENCE ANNOTATION_TYPES_ID_SEQ; | |
58 | |
59 CREATE TABLE annotation_types ( | |
60 id int PRIMARY KEY NOT NULL, | |
61 name VARCHAR(256) NOT NULL UNIQUE | |
62 ); | |
63 | |
64 -- Some object (eg. Hafen) at a segment of river | |
65 -- plus its position. | |
66 CREATE SEQUENCE ANNOTATIONS_ID_SEQ; | |
67 | |
68 CREATE TABLE annotations ( | |
69 id int PRIMARY KEY NOT NULL, | |
70 range_id int NOT NULL REFERENCES ranges(id), | |
71 attribute_id int NOT NULL REFERENCES attributes(id), | |
72 position_id int REFERENCES positions(id), | |
73 edge_id int REFERENCES edges(id), | |
74 type_id int REFERENCES annotation_types(id) | |
75 ); | |
76 | |
77 -- Pegel | |
78 CREATE SEQUENCE GAUGES_ID_SEQ; | |
79 | |
80 CREATE TABLE gauges ( | |
81 id int PRIMARY KEY NOT NULL, | |
82 name VARCHAR(256) NOT NULL, | |
83 river_id int NOT NULL REFERENCES rivers(id), | |
84 station NUMERIC NOT NULL UNIQUE, | |
85 aeo NUMERIC NOT NULL, | |
86 official_number int8 UNIQUE, | |
87 | |
88 -- Pegelnullpunkt | |
89 datum NUMERIC NOT NULL, | |
90 -- Streckengueltigkeit | |
91 range_id int REFERENCES ranges (id), | |
92 | |
93 UNIQUE (name, river_id), | |
94 UNIQUE (river_id, station) | |
95 ); | |
96 | |
97 -- Type of a Hauptwert 'W', 'Q', 'D', etc. | |
98 CREATE SEQUENCE MAIN_VALUE_TYPES_ID_SEQ; | |
99 | |
100 CREATE TABLE main_value_types ( | |
101 id int PRIMARY KEY NOT NULL, | |
102 name VARCHAR(256) NOT NULL UNIQUE | |
103 ); | |
104 | |
105 -- Named type of a Hauptwert (eg. HQ100) | |
106 CREATE SEQUENCE NAMED_MAIN_VALUES_ID_SEQ; | |
107 | |
108 CREATE TABLE named_main_values ( | |
109 id int PRIMARY KEY NOT NULL, | |
110 name VARCHAR(256) NOT NULL UNIQUE, | |
111 type_id int NOT NULL REFERENCES main_value_types(id), | |
112 UNIQUE (name, type_id) | |
113 ); | |
114 | |
115 -- Table for time intervals | |
116 CREATE SEQUENCE TIME_INTERVALS_ID_SEQ; | |
117 | |
118 CREATE TABLE time_intervals ( | |
119 id int PRIMARY KEY NOT NULL, | |
120 start_time TIMESTAMP NOT NULL, | |
121 stop_time TIMESTAMP, | |
122 CHECK (start_time <= stop_time) | |
123 ); | |
124 | |
125 -- Stammdaten | |
126 CREATE SEQUENCE MAIN_VALUES_ID_SEQ; | |
127 | |
128 CREATE TABLE main_values ( | |
129 id int PRIMARY KEY NOT NULL, | |
130 gauge_id int NOT NULL REFERENCES gauges(id), | |
131 named_value_id int NOT NULL REFERENCES named_main_values(id), | |
132 value NUMERIC NOT NULL, | |
133 | |
134 time_interval_id int REFERENCES time_intervals(id), | |
135 | |
136 -- TODO: better checks | |
137 UNIQUE (gauge_id, named_value_id, time_interval_id) | |
138 ); | |
139 | |
140 -- Abflusstafeln | |
141 CREATE SEQUENCE DISCHARGE_TABLES_ID_SEQ; | |
142 | |
143 CREATE TABLE discharge_tables ( | |
144 id int PRIMARY KEY NOT NULL, | |
145 gauge_id int NOT NULL REFERENCES gauges(id), | |
146 description VARCHAR(256) NOT NULL, | |
147 kind int NOT NULL DEFAULT 0, | |
148 time_interval_id int REFERENCES time_intervals(id) | |
149 | |
150 -- TODO: better checks | |
151 -- UNIQUE (gauge_id, kind, time_interval_id) | |
152 ); | |
153 | |
154 -- Values of the Abflusstafeln | |
155 CREATE SEQUENCE DISCHARGE_TABLE_VALUES_ID_SEQ; | |
156 | |
157 CREATE TABLE discharge_table_values ( | |
158 id int PRIMARY KEY NOT NULL, | |
159 table_id int NOT NULL REFERENCES discharge_tables(id), | |
160 q NUMERIC NOT NULL, | |
161 w NUMERIC NOT NULL, | |
162 | |
163 UNIQUE (table_id, q, w) | |
164 ); | |
165 | |
166 -- WST files | |
167 CREATE SEQUENCE WSTS_ID_SEQ; | |
168 | |
169 CREATE TABLE wsts ( | |
170 id int PRIMARY KEY NOT NULL, | |
171 river_id int NOT NULL REFERENCES rivers(id), | |
172 description VARCHAR(256) NOT NULL, | |
173 kind int NOT NULL DEFAULT 0, | |
174 -- TODO: more meta infos | |
175 UNIQUE (river_id, description) | |
176 ); | |
177 | |
178 -- columns of WST files | |
179 CREATE SEQUENCE WST_COLUMNS_ID_SEQ; | |
180 | |
181 CREATE TABLE wst_columns ( | |
182 id int PRIMARY KEY NOT NULL, | |
183 wst_id int NOT NULL REFERENCES wsts(id), | |
184 name VARCHAR(256) NOT NULL, | |
185 description VARCHAR(256), | |
186 position int NOT NULL DEFAULT 0, | |
187 | |
188 time_interval_id int REFERENCES time_intervals(id), | |
189 | |
190 UNIQUE (wst_id, name), | |
191 UNIQUE (wst_id, position) | |
192 ); | |
193 | |
194 -- w values in WST file column | |
195 CREATE SEQUENCE WST_COLUMN_VALUES_ID_SEQ; | |
196 | |
197 CREATE TABLE wst_column_values ( | |
198 id int PRIMARY KEY NOT NULL, | |
199 wst_column_id int NOT NULL REFERENCES wst_columns(id), | |
200 position NUMERIC NOT NULL, | |
201 w NUMERIC NOT NULL, | |
202 | |
203 UNIQUE (position, wst_column_id), | |
204 UNIQUE (position, wst_column_id, w) | |
205 ); | |
206 | |
207 -- bind q values to range | |
208 CREATE SEQUENCE WST_Q_RANGES_ID_SEQ; | |
209 | |
210 CREATE TABLE wst_q_ranges ( | |
211 id int PRIMARY KEY NOT NULL, | |
212 range_id int NOT NULL REFERENCES ranges(id), | |
213 q NUMERIC NOT NULL | |
214 ); | |
215 | |
216 -- bind q ranges to wst columns | |
217 CREATE SEQUENCE WST_COLUMN_Q_RANGES_ID_SEQ; | |
218 | |
219 CREATE TABLE wst_column_q_ranges ( | |
220 id int PRIMARY KEY NOT NULL, | |
221 wst_column_id int NOT NULL REFERENCES wst_columns(id), | |
222 wst_q_range_id int NOT NULL REFERENCES wst_q_ranges(id), | |
223 | |
224 UNIQUE (wst_column_id, wst_q_range_id) | |
225 ); | |
226 | |
227 CREATE VIEW wst_value_table AS | |
228 SELECT wcv.position AS position, | |
229 w, | |
230 (SELECT q | |
231 FROM wst_column_q_ranges wcqr | |
232 JOIN wst_q_ranges wqr | |
233 ON wcqr.wst_q_range_id = wqr.id | |
234 JOIN ranges r | |
235 ON r.id = wqr.range_id | |
236 WHERE wcqr.wst_column_id = wc.id | |
237 AND wcv.position BETWEEN r.a AND r.b) AS q, | |
238 wc.position AS column_pos, | |
239 w.id AS wst_id | |
240 FROM wst_column_values wcv | |
241 JOIN wst_columns wc | |
242 ON wcv.wst_column_id = wc.id | |
243 JOIN wsts w | |
244 ON wc.wst_id = w.id | |
245 ORDER BY wcv.position ASC, | |
246 wc.position DESC; | |
247 | |
248 -- view to select the w values of a WST | |
249 CREATE VIEW wst_w_values AS | |
250 SELECT wcv."position" AS km, | |
251 wcv.w AS w, | |
252 wc."position" AS column_pos, | |
253 w.id AS wst_id | |
254 FROM wst_column_values wcv | |
255 JOIN wst_columns wc ON wcv.wst_column_id = wc.id | |
256 JOIN wsts w ON wc.wst_id = w.id | |
257 ORDER BY wcv."position", wc."position"; | |
258 | |
259 -- view to select the q values of a WST | |
260 CREATE VIEW wst_q_values AS | |
261 SELECT wc.position AS column_pos, | |
262 wqr.q AS q, | |
263 r.a AS a, | |
264 r.b AS b, | |
265 wc.wst_id AS wst_id | |
266 FROM wst_column_q_ranges wcqr | |
267 JOIN wst_q_ranges wqr ON wcqr.wst_q_range_id = wqr.id | |
268 JOIN ranges r ON wqr.range_id = r.id | |
269 JOIN wst_columns wc ON wcqr.wst_column_id = wc.id | |
270 ORDER BY wc.position, wcqr.wst_column_id, r.a; | |
271 | |
272 -- data for the cross-sections | |
273 | |
274 CREATE SEQUENCE CROSS_SECTIONS_ID_SEQ; | |
275 | |
276 CREATE TABLE cross_sections ( | |
277 id int PRIMARY KEY NOT NULL, | |
278 river_id int NOT NULL REFERENCES rivers(id), | |
279 time_interval_id int REFERENCES time_intervals(id), | |
280 description VARCHAR(256) | |
281 ); | |
282 | |
283 -- Indices for faster access of the points | |
284 CREATE INDEX cross_section_lines_km_idx | |
285 ON cross_section_lines(km); | |
286 CREATE INDEX cross_section_points_line_idx | |
287 ON cross_section_points(cross_section_line_id); | |
288 | |
289 CREATE SEQUENCE CROSS_SECTION_LINES_ID_SEQ; | |
290 | |
291 CREATE TABLE cross_section_lines ( | |
292 id int PRIMARY KEY NOT NULL, | |
293 km NUMERIC NOT NULL, | |
294 cross_section_id int NOT NULL REFERENCES cross_sections(id), | |
295 UNIQUE (km, cross_section_id) | |
296 ); | |
297 | |
298 CREATE SEQUENCE CROSS_SECTION_POINTS_ID_SEQ; | |
299 | |
300 CREATE TABLE cross_section_points ( | |
301 id int PRIMARY KEY NOT NULL, | |
302 cross_section_line_id int NOT NULL REFERENCES cross_section_lines(id), | |
303 col_pos int NOT NULL, | |
304 x NUMERIC NOT NULL, | |
305 y NUMERIC NOT NULL, | |
306 UNIQUE (cross_section_line_id, col_pos) | |
307 ); | |
308 | |
309 -- Hydraulische Kenngroessen | |
310 | |
311 CREATE SEQUENCE HYKS_ID_SEQ; | |
312 | |
313 CREATE TABLE hyks ( | |
314 id int PRIMARY KEY NOT NULL, | |
315 river_id int NOT NULL REFERENCES rivers(id), | |
316 description VARCHAR(256) NOT NULL | |
317 ); | |
318 | |
319 CREATE SEQUENCE HYK_ENTRIES_ID_SEQ; | |
320 | |
321 CREATE TABLE hyk_entries ( | |
322 id int PRIMARY KEY NOT NULL, | |
323 hyk_id int NOT NULL REFERENCES hyks(id), | |
324 km NUMERIC NOT NULL, | |
325 measure TIMESTAMP, | |
326 UNIQUE (hyk_id, km) | |
327 ); | |
328 | |
329 CREATE SEQUENCE HYK_FORMATIONS_ID_SEQ; | |
330 | |
331 CREATE TABLE hyk_formations ( | |
332 id int PRIMARY KEY NOT NULL, | |
333 formation_num int NOT NULL DEFAULT 0, | |
334 hyk_entry_id int NOT NULL REFERENCES hyk_entries(id), | |
335 top NUMERIC NOT NULL, | |
336 bottom NUMERIC NOT NULL, | |
337 distance_vl NUMERIC NOT NULL, | |
338 distance_hf NUMERIC NOT NULL, | |
339 distance_vr NUMERIC NOT NULL, | |
340 UNIQUE (hyk_entry_id, formation_num) | |
341 ); | |
342 | |
343 CREATE SEQUENCE HYK_FLOW_ZONE_TYPES_ID_SEQ; | |
344 | |
345 CREATE TABLE hyk_flow_zone_types ( | |
346 id int PRIMARY KEY NOT NULL, | |
347 name VARCHAR(50) NOT NULL UNIQUE, | |
348 description VARCHAR(256) | |
349 ); | |
350 | |
351 CREATE SEQUENCE HYK_FLOW_ZONES_ID_SEQ; | |
352 | |
353 CREATE TABLE hyk_flow_zones ( | |
354 id int PRIMARY KEY NOT NULL, | |
355 formation_id int NOT NULL REFERENCES hyk_formations(id), | |
356 type_id int NOT NULL REFERENCES hyk_flow_zone_types(id), | |
357 a NUMERIC NOT NULL, | |
358 b NUMERIC NOT NULL, | |
359 CHECK (a <= b) | |
360 ); | |
361 | |
362 CREATE VIEW official_lines | |
363 AS | |
364 SELECT w.river_id AS river_id, | |
365 w.id AS wst_id, | |
366 wc.id AS wst_column_id, | |
367 wc.name AS name, | |
368 wc.position AS wst_column_pos | |
369 FROM wsts w | |
370 JOIN wst_columns wc | |
371 ON wc.wst_id = w.id | |
372 WHERE w.kind = 3; | |
373 | |
374 CREATE VIEW q_main_values | |
375 AS | |
376 SELECT riv.id AS river_id, | |
377 g.id AS gauge_id, | |
378 g.name AS gauge_name, | |
379 r.a AS a, | |
380 r.b AS b, | |
381 REGEXP_REPLACE( | |
382 nmv.name, E'[:space:]*\\(.*\\)[:space:]*', '') AS name, | |
383 CAST(mv.value AS NUMERIC(38, 2)) AS value | |
384 FROM main_values mv | |
385 JOIN named_main_values nmv | |
386 ON mv.named_value_id = nmv.id | |
387 JOIN main_value_types mvt | |
388 ON nmv.type_id = mvt.id | |
389 JOIN gauges g | |
390 ON mv.gauge_id = g.id | |
391 JOIN ranges r | |
392 ON g.range_id = r.id | |
393 JOIN rivers riv | |
394 ON g.river_id = riv.id | |
395 WHERE mvt.name = 'Q' | |
396 ORDER BY g.id, CAST(mv.value AS NUMERIC(38,2)); | |
397 | |
398 CREATE VIEW official_q_values | |
399 AS | |
400 SELECT ol.river_id AS river_id, | |
401 wst_id, | |
402 wst_column_id, | |
403 gauge_id, | |
404 gauge_name, | |
405 a, | |
406 b, | |
407 ol.name, | |
408 value, | |
409 wst_column_pos | |
410 FROM official_lines ol | |
411 JOIN q_main_values qmv | |
412 ON ol.river_id = qmv.river_id | |
413 AND ol.name = qmv.name; | |
414 | |
415 COMMIT; |