bjoern@2351: -- ANNOTATION_TYPES bjoern@2351: CREATE SEQUENCE ANNOTATION_TYPES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE annotation_types ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5783: name VARCHAR2(255) NOT NULL UNIQUE, bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- ANNOTATIONS bjoern@2351: CREATE SEQUENCE ANNOTATIONS_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE annotations ( tom@5783: id NUMBER(38,0) NOT NULL, tom@5783: attribute_id NUMBER(38,0) NOT NULL, bjoern@2351: edge_id NUMBER(38,0), bjoern@2351: position_id NUMBER(38,0), bjoern@2351: range_id NUMBER(38,0), bjoern@2351: type_id NUMBER(38,0), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- ATTRIBUTES bjoern@2351: CREATE SEQUENCE ATTRIBUTES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE attributes ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5783: value VARCHAR2(255) NOT NULL UNIQUE, bjoern@2351: primary key (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- CROSS_SECTION_LINES bjoern@2351: CREATE SEQUENCE CROSS_SECTION_LINES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE cross_section_lines ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@6030: km NUMBER(38,2) NOT NULL, tom@6030: cross_section_id NUMBER(38,0) NOT NULL, tom@6030: PRIMARY KEY (id), tom@6030: UNIQUE (km, cross_section_id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- CROSS_SECTION_POINTS bjoern@2351: CREATE SEQUENCE CROSS_SECTION_POINTS_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE cross_section_points ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@6030: col_pos NUMBER(38,0) NOT NULL, tom@6030: x NUMBER(38,2) NOT NULL, tom@6030: y NUMBER(38,2) NOT NULL, tom@6030: cross_section_line_id NUMBER(38,0) NOT NULL, tom@6030: PRIMARY KEY (id), bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- CROSS_SECTIONS ingo@2855: CREATE SEQUENCE CROSS_SECTIONS_ID_SEQ; bjoern@2351: ingo@2855: CREATE TABLE cross_sections ( bjoern@2351: id NUMBER(38,0) NOT NULL, bjoern@2351: description VARCHAR2(255), tom@6030: river_id NUMBER(38,0) NOT NULL, bjoern@2351: time_interval_id NUMBER(38,0), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: sascha@3339: -- Indices for faster access of the points sascha@3339: CREATE INDEX cross_section_lines_km_idx sascha@3339: ON cross_section_lines(km); sascha@3339: CREATE INDEX cross_section_points_line_idx sascha@3339: ON cross_section_points(cross_section_line_id); bjoern@2351: bjoern@2351: -- DISCHARGE_TABLE_VALUES bjoern@2351: CREATE SEQUENCE DISCHARGE_TABLE_VALUES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE discharge_table_values ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5897: q NUMBER(38,4) NOT NULL, tom@5783: w NUMBER(38,2) NOT NULL, tom@5783: table_id NUMBER(38,0) NOT NULL, tom@5783: UNIQUE (table_id, q, w), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- DISCHARGE_TABLES bjoern@2351: CREATE SEQUENCE DISCHARGE_TABLES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE discharge_tables ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5783: description VARCHAR2(255) NOT NULL, teichmann@4776: bfg_id VARCHAR2(50), tom@5783: kind NUMBER(38,0) NOT NULL DEFAULT 0, tom@5783: gauge_id NUMBER(38,0) NOT NULL, bjoern@2351: time_interval_id NUMBER(38,0), tom@5883: PRIMARY KEY (id), tom@5923: UNIQUE(gauge_id, bfg_id, kind) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- EDGES bjoern@2351: CREATE SEQUENCE EDGES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE edges ( bjoern@2351: id NUMBER(38,0) NOT NULL, bjoern@2351: bottom NUMBER(38,2), bjoern@2351: top NUMBER(38,2), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- GAUGES bjoern@2351: CREATE SEQUENCE GAUGES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE gauges ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5207: aeo NUMBER(38,2) NOT NULL, tom@5207: datum NUMBER(38,2) NOT NULL, tom@5207: name VARCHAR2(255) NOT NULL, tom@5207: station NUMBER(38,2) NOT NULL, tom@5894: official_number NUMBER(38,0), tom@5207: range_id NUMBER(38,0) NOT NULL, tom@5894: -- TODO: remove river id here because range_id references river already tom@5783: river_id NUMBER(38,0) NOT NULL, tom@5207: PRIMARY KEY (id), tom@5207: UNIQUE (name, river_id), tom@5894: UNIQUE (official_number, river_id), tom@5207: UNIQUE (river_id, station) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- HYK_ENTRIES bjoern@2351: CREATE SEQUENCE HYK_ENTRIES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE hyk_entries ( bjoern@2351: id NUMBER(38,0) NOT NULL, bjoern@2351: km NUMBER(38,2), bjoern@2351: measure TIMESTAMP, bjoern@2351: hyk_id NUMBER(38,0), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- HYK_FLOW_ZONE_TYPES bjoern@2351: CREATE SEQUENCE HYK_FLOW_ZONE_TYPES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE hyk_flow_zone_types ( bjoern@2351: id NUMBER(38,0) NOT NULL, bjoern@2351: description VARCHAR2(255), bjoern@2351: name VARCHAR2(255), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- HYK_FLOW_ZONES bjoern@2351: CREATE SEQUENCE HYK_FLOW_ZONES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE hyk_flow_zones ( bjoern@2351: id NUMBER(38,0) NOT NULL, bjoern@2351: a NUMBER(38,2), bjoern@2351: b NUMBER(38,2), bjoern@2351: formation_id NUMBER(38,0), bjoern@2351: type_id NUMBER(38,0), bjoern@2351: primary key (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- HYK_FORMATIONS bjoern@2351: CREATE SEQUENCE HYK_FORMATIONS_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE hyk_formations ( bjoern@2351: id NUMBER(38,0) NOT NULL, bjoern@2351: bottom NUMBER(38,2), bjoern@2351: distance_hf NUMBER(38,2), bjoern@2351: distance_vl NUMBER(38,2), bjoern@2351: distance_vr NUMBER(38,2), bjoern@2351: formation_num NUMBER(38,0), bjoern@2351: top NUMBER(38,2), bjoern@2351: hyk_entry_id NUMBER(38,0), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- HYKS bjoern@2351: CREATE SEQUENCE HYKS_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE hyks ( bjoern@2351: id NUMBER(38,0) NOT NULL, bjoern@2351: description VARCHAR2(255), bjoern@2351: river_id NUMBER(38,0), bjoern@2351: primary key (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- MAIN_VALUE_TYPES bjoern@2351: CREATE SEQUENCE MAIN_VALUE_TYPES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE main_value_types ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5783: name VARCHAR2(255) NOT NULL UNIQUE, bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- MAIN_VALUES bjoern@2351: CREATE SEQUENCE MAIN_VALUES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE main_values ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5783: value NUMBER(38,2) NOT NULL, tom@5783: gauge_id NUMBER(38,0) NOT NULL, tom@5783: named_value_id NUMBER(38,0) NOT NULL, bjoern@2351: time_interval_id NUMBER(38,0), tom@5783: tom@5783: -- TODO: better checks tom@5783: UNIQUE (gauge_id, named_value_id, time_interval_id), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- NAMED_MAIN_VALUES bjoern@2351: CREATE SEQUENCE NAMED_MAIN_VALUES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE named_main_values ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5915: name VARCHAR2(256) NOT NULL, tom@5783: type_id NUMBER(38,0) NOT NULL, bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- POSITIONS bjoern@2351: CREATE SEQUENCE POSITIONS_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE positions ( bjoern@2353: id NUMBER(38,0) NOT NULL, tom@5783: value VARCHAR2(255 char) NOT NULL UNIQUE, bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: --- RANGES bjoern@2351: CREATE SEQUENCE RANGES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE ranges ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5158: a NUMBER(38,10) NOT NULL, sascha@2367: b NUMBER(38,10), bjoern@2351: river_id NUMBER(38,0), tom@5783: UNIQUE (river_id, a, b), tom@5783: PRIMARY KEY (id) bjoern@2351: ); tom@5321: bjoern@2351: bjoern@2351: bjoern@2351: -- RIVERS bjoern@2351: CREATE SEQUENCE RIVERS_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE rivers ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5893: official_number NUMBER(38,0), tom@5783: km_up NUMBER(38,0) NOT NULL DEFAULT 0, tom@5783: name VARCHAR2(255) NOT NULL UNIQUE, tom@5783: wst_unit_id NUMBER(38,0) NOT NULL, bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- TIME_INTERVALS bjoern@2351: CREATE SEQUENCE TIME_INTERVALS_ID_SEQ; bjoern@2351: aheinecke@5206: CREATE TABLE time_intervals ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5158: start_time TIMESTAMP NOT NULL, bjoern@2351: stop_time TIMESTAMP, tom@5158: PRIMARY KEY (id), tom@5158: CHECK (start_time <= stop_time) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: --- UNITS bjoern@2351: CREATE SEQUENCE UNITS_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE units ( bjoern@2353: id NUMBER(38,0) NOT NULL, tom@5783: name VARCHAR2(255) NOT NULL UNIQUE, bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- WST_COLUMN_Q_RANGES bjoern@2351: CREATE SEQUENCE WST_COLUMN_Q_RANGES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE wst_column_q_ranges ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5783: wst_column_id NUMBER(38,0) NOT NULL, tom@5783: wst_q_range_id NUMBER(38,0) NOT NULL, tom@5783: UNIQUE (wst_column_id, wst_q_range_id), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- WST_COLUMN_VALUES bjoern@2351: CREATE SEQUENCE WST_COLUMN_VALUES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE wst_column_values ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5783: position NUMBER(38,5) NOT NULL, tom@5783: w NUMBER(38,5) NOT NULL, tom@5783: wst_column_id NUMBER(38,0) NOT NULL, tom@5783: UNIQUE (position, wst_column_id), tom@5783: UNIQUE (position, wst_column_id, w), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- WST_COLUMNS bjoern@2351: CREATE SEQUENCE WST_COLUMNS_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE wst_columns ( bjoern@2351: id NUMBER(38,0) NOT NULL, bjoern@2351: description VARCHAR2(255), tom@5783: name VARCHAR2(255) NOT NULL, tom@6502: source VARCHAR(256), tom@5783: position NUMBER(38,0) NOT NULL DEFAULT 0, tom@6011: time_interval_id NUMBER(38,0), tom@5783: wst_id NUMBER(38,0) NOT NULL, tom@5783: UNIQUE (wst_id, name), tom@5783: UNIQUE (wst_id, position), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2351: -- WST_Q_RANGES bjoern@2351: CREATE SEQUENCE WST_Q_RANGES_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE wst_q_ranges ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5783: q NUMBER(38,5) NOT NULL, tom@5783: range_id NUMBER(38,0) NOT NULL, bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: teichmann@6300: -- OFFICIAL_LINES teichmann@6300: CREATE SEQUENCE OFFICIAL_LINES_ID_SEQ; teichmann@6300: teichmann@6300: CREATE TABLE official_lines ( teichmann@6300: id NUMBER(38,0) NOT NULL, teichmann@6300: wst_column_id NUMBER(38,0) NOT NULL, teichmann@6300: named_main_value_id NUMBER(38,0) NOT NULL, teichmann@6367: UNIQUE (wst_column_id, named_main_value_id), teichmann@6367: PRIMARY KEY (id) teichmann@6300: ); bjoern@2351: bjoern@2351: -- WSTS tom@5224: --lookup table for wst kinds tom@5224: CREATE TABLE wst_kinds ( tom@5224: id NUMBER PRIMARY KEY NOT NULL, tom@5224: kind VARCHAR(64) NOT NULL tom@5224: ); tom@5224: INSERT INTO wst_kinds (id, kind) VALUES (0, 'basedata'); tom@5224: INSERT INTO wst_kinds (id, kind) VALUES (1, 'basedata_additionals_marks'); tom@5224: INSERT INTO wst_kinds (id, kind) VALUES (2, 'basedata_fixations_wst'); tom@5224: INSERT INTO wst_kinds (id, kind) VALUES (3, 'basedata_officials'); tom@5224: INSERT INTO wst_kinds (id, kind) VALUES (4, 'basedata_heightmarks-points-relative_points'); tom@5224: INSERT INTO wst_kinds (id, kind) VALUES (5, 'basedata_flood-protections_relative_points'); tom@5224: INSERT INTO wst_kinds (id, kind) VALUES (6, 'morpho_waterlevel-differences'); tom@5224: INSERT INTO wst_kinds (id, kind) VALUES (7, 'morpho_waterlevels'); tom@5224: tom@5224: bjoern@2351: CREATE SEQUENCE WSTS_ID_SEQ; bjoern@2351: bjoern@2351: CREATE TABLE wsts ( bjoern@2351: id NUMBER(38,0) NOT NULL, tom@5783: description VARCHAR2(255) NOT NULL, tom@5783: kind NUMBER(38,0) NOT NULL, tom@5783: river_id NUMBER(38,0) NOT NULL, tom@5783: UNIQUE (river_id, description), bjoern@2351: PRIMARY KEY (id) bjoern@2351: ); bjoern@2351: bjoern@2351: bjoern@2352: -- ADD CONSTRAINTs aheinecke@5113: ALTER TABLE annotations ADD CONSTRAINT cAnnotationsAttributes FOREIGN KEY (attribute_id) REFERENCES attributes; bjoern@2352: ALTER TABLE annotations ADD CONSTRAINT cAnnotationsEdges FOREIGN KEY (edge_id) REFERENCES edges; bjoern@2352: ALTER TABLE annotations ADD CONSTRAINT cAnnotationsPositions FOREIGN KEY (position_id) REFERENCES positions; bjoern@2352: ALTER TABLE annotations ADD CONSTRAINT cAnnotationsTypes FOREIGN KEY (type_id) REFERENCES annotation_types; bjoern@2352: ALTER TABLE cross_sections ADD CONSTRAINT cCrossSectionsTimeIntervals FOREIGN KEY (time_interval_id) REFERENCES time_intervals; bjoern@2352: ALTER TABLE discharge_tables ADD CONSTRAINT cDischargeTablesTime_intervals FOREIGN KEY (time_interval_id) REFERENCES time_intervals; bjoern@2352: ALTER TABLE hyk_flow_zones ADD CONSTRAINT cHykFlowZonesHykFlowZoneTypes FOREIGN KEY (type_id) REFERENCES hyk_flow_zone_types; aheinecke@5113: ALTER TABLE main_values ADD CONSTRAINT cMainValuesNamedMainValues FOREIGN KEY (named_value_id) REFERENCES named_main_values; bjoern@2352: ALTER TABLE main_values ADD CONSTRAINT cMainValuesTimeIntervals FOREIGN KEY (time_interval_id) REFERENCES time_intervals; bjoern@2352: ALTER TABLE named_main_values ADD CONSTRAINT cNamedMainValuesMainValueTypes FOREIGN KEY (type_id) REFERENCES main_value_types; bjoern@2352: ALTER TABLE rivers ADD CONSTRAINT cRiversUnits FOREIGN KEY (wst_unit_id) REFERENCES units; bjoern@2352: ALTER TABLE wst_columns ADD CONSTRAINT cWstColumnsTime_intervals FOREIGN KEY (time_interval_id) REFERENCES time_intervals; aheinecke@5113: aheinecke@5113: -- Cascading references aheinecke@5113: ALTER TABLE annotations ADD CONSTRAINT cAnnotationsRanges FOREIGN KEY (range_id) REFERENCES ranges ON DELETE CASCADE; aheinecke@5113: ALTER TABLE cross_section_lines ADD CONSTRAINT cQPSLinesCrossSections FOREIGN KEY (cross_section_id) REFERENCES cross_sections ON DELETE CASCADE; aheinecke@5113: ALTER TABLE cross_section_points ADD CONSTRAINT cQPSPointsCrossSectionLines FOREIGN KEY (cross_section_line_id) REFERENCES cross_section_lines ON DELETE CASCADE; aheinecke@5113: ALTER TABLE cross_sections ADD CONSTRAINT cCrossSectionsRivers FOREIGN KEY (river_id) REFERENCES rivers ON DELETE CASCADE; aheinecke@5113: ALTER TABLE discharge_tables ADD CONSTRAINT cDischargeTablesGauges FOREIGN KEY (gauge_id) REFERENCES gauges ON DELETE CASCADE; aheinecke@5113: ALTER TABLE discharge_table_values ADD CONSTRAINT cTableValuesDischargeTables FOREIGN KEY (table_id) REFERENCES discharge_tables ON DELETE CASCADE; aheinecke@5113: ALTER TABLE gauges ADD CONSTRAINT cGaugesRanges FOREIGN KEY (range_id) REFERENCES ranges ON DELETE CASCADE; aheinecke@5113: ALTER TABLE gauges ADD CONSTRAINT cGaugesRivers FOREIGN KEY (river_id) REFERENCES rivers ON DELETE CASCADE; aheinecke@5113: ALTER TABLE hyk_entries ADD CONSTRAINT cHykEntriesHyks FOREIGN KEY (hyk_id) REFERENCES hyks ON DELETE CASCADE; aheinecke@5113: ALTER TABLE hyk_flow_zones ADD CONSTRAINT cHykFlowZonesHykFormations FOREIGN KEY (formation_id) REFERENCES hyk_formations ON DELETE CASCADE; aheinecke@5113: ALTER TABLE hyk_formations ADD CONSTRAINT cHykFormationsHykEntries FOREIGN KEY (hyk_entry_id) REFERENCES hyk_entries ON DELETE CASCADE; aheinecke@5113: ALTER TABLE hyks ADD CONSTRAINT cHyksRivers FOREIGN KEY (river_id) REFERENCES rivers ON DELETE CASCADE; aheinecke@5113: ALTER TABLE main_values ADD CONSTRAINT cMainValuesGauges FOREIGN KEY (gauge_id) REFERENCES gauges ON DELETE CASCADE; aheinecke@5113: ALTER TABLE ranges ADD CONSTRAINT cRangesRivers FOREIGN KEY (river_id) REFERENCES rivers ON DELETE CASCADE; aheinecke@5113: ALTER TABLE wst_column_q_ranges ADD CONSTRAINT cWstColumnQRangesWstColums FOREIGN KEY (wst_column_id) REFERENCES wst_columns ON DELETE CASCADE; aheinecke@5113: ALTER TABLE wst_column_q_ranges ADD CONSTRAINT cWstColumnQRangesWstQRanges FOREIGN KEY (wst_q_range_id) REFERENCES wst_q_ranges ON DELETE CASCADE; aheinecke@5113: ALTER TABLE wst_columns ADD CONSTRAINT cWstColumnsWsts FOREIGN KEY (wst_id) REFERENCES wsts ON DELETE CASCADE; aheinecke@5113: ALTER TABLE wst_column_values ADD CONSTRAINT cWstColumnValuesWstColumns FOREIGN KEY (wst_column_id) REFERENCES wst_columns ON DELETE CASCADE; teichmann@6300: ALTER TABLE wst_q_ranges ADD CONSTRAINT cWstQRangesRanges FOREIGN KEY (range_id) REFERENCES RANGES ON LETE CASCADE; aheinecke@5113: ALTER TABLE wsts ADD CONSTRAINT cWstsRivers FOREIGN KEY (river_id) REFERENCES rivers ON DELETE CASCADE; tom@5224: ALTER TABLE wsts ADD CONSTRAINT cWstsWstKinds FOREIGN KEY (kind) REFERENCES wst_kinds; bjoern@2355: teichmann@6300: ALTER TABLE official_lines ADD CONSTRAINT cOffLinesWstColumns FOREIGN KEY (wst_column_id) REFERENCES wst_columns ON DELETE CASCADE; teichmann@6300: ALTER TABLE official_lines ADD CONSTRAINT cOffLinesNamedMainValues FOREIGN KEY (named_main_value_id) REFERENCES named_main_values ON DELETE CASCADE; teichmann@6300: bjoern@2355: -- VIEWS bjoern@2355: bjoern@2355: CREATE VIEW wst_value_table AS tom@6078: SELECT tom@6078: wcv.position AS position, tom@6078: w, tom@6078: q, tom@6078: wc.position AS column_pos, tom@6078: w.id AS wst_id tom@6078: FROM wsts w tom@6078: JOIN wst_columns wc tom@6078: ON wc.wst_id=w.id tom@6078: JOIN wst_column_q_ranges wcqr tom@6078: ON wcqr.wst_column_id=wc.id tom@6078: JOIN wst_q_ranges wqr tom@6078: ON wcqr.wst_q_range_id=wqr.id tom@6078: JOIN ranges r tom@6078: ON wqr.range_id=r.id tom@6078: JOIN wst_column_values wcv felix@6177: ON wcv.wst_column_id=wc.id AND wcv.position between r.a and r.b bjoern@2355: ORDER BY wcv.position ASC, tom@6078: wc.position DESC; bjoern@2355: bjoern@2355: -- view to select the w values of a WST bjoern@2355: CREATE VIEW wst_w_values AS bjoern@2355: SELECT wcv.position AS km, bjoern@2355: wcv.w AS w, bjoern@2355: wc.position AS column_pos, bjoern@2355: w.id AS wst_id bjoern@2355: FROM wst_column_values wcv bjoern@2355: JOIN wst_columns wc ON wcv.wst_column_id = wc.id bjoern@2355: JOIN wsts w ON wc.wst_id = w.id bjoern@2355: ORDER BY wcv.position, wc.position; bjoern@2355: bjoern@2355: -- view to select the q values of a WST bjoern@2355: CREATE VIEW wst_q_values AS bjoern@2355: SELECT wc.position AS column_pos, bjoern@2355: wqr.q AS q, bjoern@2355: r.a AS a, bjoern@2355: r.b AS b, bjoern@2355: wc.wst_id AS wst_id bjoern@2355: FROM wst_column_q_ranges wcqr bjoern@2355: JOIN wst_q_ranges wqr ON wcqr.wst_q_range_id = wqr.id bjoern@2355: JOIN ranges r ON wqr.range_id = r.id bjoern@2355: JOIN wst_columns wc ON wcqr.wst_column_id = wc.id bjoern@2355: ORDER BY wc.position, wcqr.wst_column_id, r.a; sascha@3335: teichmann@4651: CREATE VIEW wst_ranges teichmann@4651: AS teichmann@4651: SELECT wc.id AS wst_column_id, teichmann@4651: wc.wst_id AS wst_id, teichmann@4651: Min(wcv.position) AS a, teichmann@4651: Max(wcv.position) AS b teichmann@4651: FROM wst_columns wc teichmann@4651: JOIN wst_column_values wcv teichmann@4651: ON wc.id = wcv.wst_column_id teichmann@4651: GROUP BY wc.id, teichmann@4651: wc.wst_id;