comparison backend/doc/documentation/de/importer-geodaesie.tex @ 8826:2ba30caa5571

Whitespace cleanup.
author Tom Gottfried <tom@intevation.de>
date Tue, 16 May 2017 16:00:55 +0200
parents 884617654878
children 21e276cef740
comparison
equal deleted inserted replaced
8825:3e212106455c 8826:2ba30caa5571
18 Parser, der die speziellen Attribute eines Shapefiles liest und in die entsprechende 18 Parser, der die speziellen Attribute eines Shapefiles liest und in die entsprechende
19 Relation der Datenbank schreibt. Die Parser sind speziell auf das 19 Relation der Datenbank schreibt. Die Parser sind speziell auf das
20 Dateisystem der BfG ausgerichtet. So wird beispielsweise erwartet, dass die Shapefiles der 20 Dateisystem der BfG ausgerichtet. So wird beispielsweise erwartet, dass die Shapefiles der
21 Gewässerachse im Ordner $Geodaesie/Flussachse+km$ liegen. Weitere Informationen zu 21 Gewässerachse im Ordner $Geodaesie/Flussachse+km$ liegen. Weitere Informationen zu
22 den einzelnen Parsern sind Kapitel \ref{Beschreibung der Parser} zu 22 den einzelnen Parsern sind Kapitel \ref{Beschreibung der Parser} zu
23 entnehmen. 23 entnehmen.
24 24
25 Damit die Geodaten eines Shapes später eindeutig in der Datenbank identifiziert 25 Damit die Geodaten eines Shapes später eindeutig in der Datenbank identifiziert
26 werden können, wird für jede Geometrie der Pfad des Shapes im Dateisystem 26 werden können, wird für jede Geometrie der Pfad des Shapes im Dateisystem
27 im Datenbankfeld 'path' gespeichert. Anwendungen, die auf der Datenbank 27 im Datenbankfeld 'path' gespeichert. Anwendungen, die auf der Datenbank
28 aufbauen, können die Geodaten eines Shapefiles später anhand dieses Merkmals 28 aufbauen, können die Geodaten eines Shapefiles später anhand dieses Merkmals
29 gruppieren und anzeigen. 29 gruppieren und anzeigen.
30 30
31 Bitte beachten Sie, dass der Geodaten Importer aufgrund der eingesetzten 31 Bitte beachten Sie, dass der Geodaten Importer aufgrund der eingesetzten
32 Technologien derzeit nicht in der Lage ist, lesend auf die Oracle-Datenbank 32 Technologien derzeit nicht in der Lage ist, lesend auf die Oracle-Datenbank
33 zuzugreifen. Entsprechend kann beim Import nicht festgestellt werden, ob sich 33 zuzugreifen. Entsprechend kann beim Import nicht festgestellt werden, ob sich
34 die Daten eines Shapefiles bereits in der Datenbank befinden, oder nicht. 34 die Daten eines Shapefiles bereits in der Datenbank befinden, oder nicht.
35 Ein erneuter Import der Geodaten würde also dazu führen, dass Geometrien doppelt in der 35 Ein erneuter Import der Geodaten würde also dazu führen, dass Geometrien doppelt in der
36 Datenbank abgelegt werden. 36 Datenbank abgelegt werden.
37 37
38 \subsection{Koordination-Transformation} 38 \subsection{Koordination-Transformation}
39 Für die Transformation der Daten verwendet GDAL wiederum die PROJ4-Bibliothek. 39 Für die Transformation der Daten verwendet GDAL wiederum die PROJ4-Bibliothek.
40 Die Daten werden vor dem Schreiben in die Datenbank alle 40 Die Daten werden vor dem Schreiben in die Datenbank alle
41 in die Gauß-Krüger-Projektion Zone 3 (EPSG-Code 31467) transformiert. 41 in die Gauß-Krüger-Projektion Zone 3 (EPSG-Code 31467) transformiert.
42 Ist für die zu importierenden Daten keine Projektion ersichtlich 42 Ist für die zu importierenden Daten keine Projektion ersichtlich
43 (fehlende \textit{*.prj}-Datei), so findet keine Transformation statt. 43 (fehlende \textit{*.prj}-Datei), so findet keine Transformation statt.
44 Dies führt nur zu Problemen mit dem Fachdienst FLYS, falls die Daten nicht 44 Dies führt nur zu Problemen mit dem Fachdienst FLYS, falls die Daten nicht
45 bereits in der genannten Projektion vorlagen. 45 bereits in der genannten Projektion vorlagen.
46 46
47 Im Falle der Digitalen Geländemodelle (DGM) findet keine Transformation statt, 47 Im Falle der Digitalen Geländemodelle (DGM) findet keine Transformation statt,
48 da zu diesen lediglich Metadaten in der Datenbank gespeichert werden 48 da zu diesen lediglich Metadaten in der Datenbank gespeichert werden
49 (siehe Kapitel \ref{dgm_parser}), 49 (siehe Kapitel \ref{dgm_parser}),
50 während die Daten selbst von der Anwendung Dive4Elements River 50 während die Daten selbst von der Anwendung Dive4Elements River
51 aus dem Dateisystem geholt werden. 51 aus dem Dateisystem geholt werden.
52 Für Berechnungen mit den DGM werden die Geometrien aus der Datenbank 52 Für Berechnungen mit den DGM werden die Geometrien aus der Datenbank
53 in Dive4Elements River in die Projektion des jeweiligen DGM transformiert. 53 in Dive4Elements River in die Projektion des jeweiligen DGM transformiert.
54 Daher ist es besonders wichtig, dass die Angaben des EPSG-Codes 54 Daher ist es besonders wichtig, dass die Angaben des EPSG-Codes
55 in der Spalte SRID in DGMs.csv korrekt sind (siehe Kapitel \ref{dgm_parser}) 55 in der Spalte SRID in DGMs.csv korrekt sind (siehe Kapitel \ref{dgm_parser})
56 56
57 \subsection{Logfile} 57 \subsection{Logfile}
58 Der Erfolg oder Misserfolg eines Shape-Imports wird 58 Der Erfolg oder Misserfolg eines Shape-Imports wird
59 im Logfile vermerkt. Folgende Einträge können dem Logfile 59 im Logfile vermerkt. Folgende Einträge können dem Logfile
60 entnommen werden: 60 entnommen werden:
61 61
62 \textbf{INFO: Inserted \# features} 62 \textbf{INFO: Inserted \# features}
63 \\Gibt die Anzahl der erfolgreich importierten Features an. 63 \\Gibt die Anzahl der erfolgreich importierten Features an.
70 werden konnten. Wenn etwa Punkte erwartet wurden aber sich im Shapefile 70 werden konnten. Wenn etwa Punkte erwartet wurden aber sich im Shapefile
71 Polygone befanden. 71 Polygone befanden.
72 72
73 \textbf{INFO: Did not import values from fields: '...' ...} 73 \textbf{INFO: Did not import values from fields: '...' ...}
74 \\Der Importer schreibt neben der geographischen Information weitere 74 \\Der Importer schreibt neben der geographischen Information weitere
75 Attribut-Daten in die Datenbank. 75 Attribut-Daten in die Datenbank.
76 Attribut-Spalten die nicht importiert wurden (z.B. auf Grund 76 Attribut-Spalten die nicht importiert wurden (z.B. auf Grund
77 von Tippfehlern oder unterschiedlicher Schreibweise), 77 von Tippfehlern oder unterschiedlicher Schreibweise),
78 werden wie angegeben im Logfile aufgeführt. 78 werden wie angegeben im Logfile aufgeführt.
79 79
80 \textbf{ERROR: No source SRS given! No transformation possible!} 80 \textbf{ERROR: No source SRS given! No transformation possible!}
93 93
94 \textbf{ERROR 1: ORA-01017: invalid username/password; logon denied} 94 \textbf{ERROR 1: ORA-01017: invalid username/password; logon denied}
95 \\Es konnte keine Verbindung zur Oracle Datenbank hergestellt werden. Prüfen Sie 95 \\Es konnte keine Verbindung zur Oracle Datenbank hergestellt werden. Prüfen Sie
96 die Verbindungseinstellungen. 96 die Verbindungseinstellungen.
97 97
98 Weitere Fehler, die von der Oracle-Datenbank kommen, können ebenfalls im 98 Weitere Fehler, die von der Oracle-Datenbank kommen, können ebenfalls im
99 Logfile angezeigt werden. 99 Logfile angezeigt werden.
100 100
101 101
102 \subsection{Beschreibung der Parser} 102 \subsection{Beschreibung der Parser}
103 \label{Beschreibung der Parser} 103 \label{Beschreibung der Parser}
115 115
116 \textbf{Attribute} 116 \textbf{Attribute}
117 \\Eine Liste der Attribute, die vom Parser aus dem Shape gelesen werden. 117 \\Eine Liste der Attribute, die vom Parser aus dem Shape gelesen werden.
118 In Klammern als alternativ bezeichnete Attribut-Namen werden in 118 In Klammern als alternativ bezeichnete Attribut-Namen werden in
119 das gleiche Datenbankfeld geschrieben, wie das vorgenannte Feld. 119 das gleiche Datenbankfeld geschrieben, wie das vorgenannte Feld.
120 Die alternativen Namen werden vom Importer zusätzlich unterstützt, 120 Die alternativen Namen werden vom Importer zusätzlich unterstützt,
121 um Dateien aus dem heterogenen Bestand der BfG unverändert 121 um Dateien aus dem heterogenen Bestand der BfG unverändert
122 importieren zu können. 122 importieren zu können.
123 123
124 Zudem werden Datenbank-Attribute beschrieben, die nicht direkt aus 124 Zudem werden Datenbank-Attribute beschrieben, die nicht direkt aus
125 Attribut-Spalten des Shapefiles gelesen werden. 125 Attribut-Spalten des Shapefiles gelesen werden.
126 126
127 \subsubsection{Achsen} 127 \subsubsection{Achsen}
128 \hspace{5mm} 128 \hspace{5mm}
129 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}} 129 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}}
130 Pfad & Geodaesie/Flussachse+km \\ 130 Pfad & Geodaesie/Flussachse+km \\
131 Geometrie & LINESTRING, MULTILINESTRING \\ 131 Geometrie & LINESTRING, MULTILINESTRING \\
132 \end{tabular*} 132 \end{tabular*}
133 133
134 Das Attribut 'name' wird auf den Namen des Shapefiles gesetzt. 134 Das Attribut 'name' wird auf den Namen des Shapefiles gesetzt.
135 Zusätzlich wird das Attribut 'kind\_id' gesetzt, welches 135 Zusätzlich wird das Attribut 'kind\_id' gesetzt, welches
136 für die aktuelle Achse (\textit{achse.shp}) 1 ist 136 für die aktuelle Achse (\textit{achse.shp}) 1 ist
137 und für sonstige Achsen (weitere Linien-Shapes) 2. 137 und für sonstige Achsen (weitere Linien-Shapes) 2.
138 138
139 Hinweis: 139 Hinweis:
140 Da die Layer-Konfiguration (Mapfiles) für die Flussachsen beim Start des 140 Da die Layer-Konfiguration (Mapfiles) für die Flussachsen beim Start des
141 Artefakt-Servers generiert werden, muss der Artefakt-Server neugestartet 141 Artefakt-Servers generiert werden, muss der Artefakt-Server neugestartet
148 Geometrie & LINESTRING, MULTILINESTRING, POLYGON, MULTIPOLYGON \\ 148 Geometrie & LINESTRING, MULTILINESTRING, POLYGON, MULTIPOLYGON \\
149 Attribute & SECTIE, STROVOER \\ 149 Attribute & SECTIE, STROVOER \\
150 \end{tabular*} 150 \end{tabular*}
151 151
152 Das Attribut 'name' wird auf den Namen des Shapefiles gesetzt. 152 Das Attribut 'name' wird auf den Namen des Shapefiles gesetzt.
153 Das Attribut 'kind' wird 1 gesetzt für Daten aus dem 153 Das Attribut 'kind' wird 1 gesetzt für Daten aus dem
154 Unterverzeichnis \textit{Linien/BfG}, 154 Unterverzeichnis \textit{Linien/BfG},
155 2 für Daten aus \textit{Linien/Land}, 155 2 für Daten aus \textit{Linien/Land},
156 3 für Daten aus \textit{Sonstige} 156 3 für Daten aus \textit{Sonstige}
157 und für alle übrigen 0. 157 und für alle übrigen 0.
158 Ausgenommen sind Dateien, in deren Namen 'Talaue' 158 Ausgenommen sind Dateien, in deren Namen 'Talaue'
159 (Groß-Klein-Schreibung irrelevant) vorkommt. 159 (Groß-Klein-Schreibung irrelevant) vorkommt.
160 160
161 Linien und Polygone werden in der Datenbank in unterschiedlichen 161 Linien und Polygone werden in der Datenbank in unterschiedlichen
162 Tabellen gespeichert. 162 Tabellen gespeichert.
163 163
164 \subsubsection{Bauwerke} 164 \subsubsection{Bauwerke}
165 \hspace{5mm} 165 \hspace{5mm}
166 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}} 166 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}}
167 Pfad & Geodaesie/Bauwerke \\ 167 Pfad & Geodaesie/Bauwerke \\
168 Geometrie & LINESTRING \\ 168 Geometrie & LINESTRING \\
169 Attribute & Name (alternativ: KWNAAM), 169 Attribute & Name (alternativ: KWNAAM),
170 km (alternativ: station, wsv-km), 170 km (alternativ: station, wsv-km),
171 z (alternativ: Höhe, Hoehe, m+NHN)\\ 171 z (alternativ: Höhe, Hoehe, m+NHN)\\
172 \end{tabular*} 172 \end{tabular*}
173 173
174 Das Attribut 'name' wird auf den Namen des Shapefiles gesetzt. 174 Das Attribut 'name' wird auf den Namen des Shapefiles gesetzt.
175 Das Attribut 'kind\_id' ist 0 für Sonstige, 175 Das Attribut 'kind\_id' ist 0 für Sonstige,
176 1 für Brücken, 2 für Wehre, 3 für Pegel. 176 1 für Brücken, 2 für Wehre, 3 für Pegel.
177 Es wird aus dem Dateinamen hergeleitet 177 Es wird aus dem Dateinamen hergeleitet
178 (\textit{bruecken.shp, wehre.shp, pegel.shp}, 178 (\textit{bruecken.shp, wehre.shp, pegel.shp},
179 teilweise auch alternative Schreibweisen unterstützt) 179 teilweise auch alternative Schreibweisen unterstützt)
180 oder je Feature gesetzt, wenn in einer Attributspalte 180 oder je Feature gesetzt, wenn in einer Attributspalte
181 die Werte 'bruecke' und 'wehr' 181 die Werte 'bruecke' und 'wehr'
182 (teilweise auch alternative Schreibweisen unterstützt) vorkommen. 182 (teilweise auch alternative Schreibweisen unterstützt) vorkommen.
183 Ausgenommen sind Dateien, in deren Namen 'Buhnen' 183 Ausgenommen sind Dateien, in deren Namen 'Buhnen'
184 (Groß-Klein-Schreibung irrelevant) vorkommt. 184 (Groß-Klein-Schreibung irrelevant) vorkommt.
185 185
186 \subsubsection{Querprofilspuren} 186 \subsubsection{Querprofilspuren}
187 \hspace{5mm} 187 \hspace{5mm}
188 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}} 188 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}}
208 \hspace{5mm} 208 \hspace{5mm}
209 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}} 209 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}}
210 Pfad & Hydrologie/HW-Marken/hw-marken.shp \\ 210 Pfad & Hydrologie/HW-Marken/hw-marken.shp \\
211 Geometrie & POINT \\ 211 Geometrie & POINT \\
212 Attribute & Ort (alternativ: Pegel), 212 Attribute & Ort (alternativ: Pegel),
213 km (alternativ: station, wsv-km, FlussKm), 213 km (alternativ: station, wsv-km, FlussKm),
214 z (alternativ: z mit anschließender Zahl, m+NHN)\\ 214 z (alternativ: z mit anschließender Zahl, m+NHN)\\
215 \end{tabular*} 215 \end{tabular*}
216 216
217 Groß-Klein-Schreibung im Dateinamen ist irrelevant. 217 Groß-Klein-Schreibung im Dateinamen ist irrelevant.
218 Für das Attribut 'year' wird im Dateinamen nach einer Jahreszahl 218 Für das Attribut 'year' wird im Dateinamen nach einer Jahreszahl
219 nach folgendem Muster gesucht: \textit{\_YYYY\_} oder \textit{-YYYY-}. 219 nach folgendem Muster gesucht: \textit{\_YYYY\_} oder \textit{-YYYY-}.
220 Gelingt dies nicht, erscheint im Logfile die Warnung 220 Gelingt dies nicht, erscheint im Logfile die Warnung
221 'Could not extract year from filename: ...'. 221 'Could not extract year from filename: ...'.
222 222
223 \subsubsection{Talaue} 223 \subsubsection{Talaue}
224 \hspace{5mm} 224 \hspace{5mm}
237 \hspace{5mm} 237 \hspace{5mm}
238 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}} 238 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}}
239 Pfad & Hydrologie/HW-Schutzanlagen \\ 239 Pfad & Hydrologie/HW-Schutzanlagen \\
240 Geometrie & LINESTRING, MULTILINESTRING, POINT \\ 240 Geometrie & LINESTRING, MULTILINESTRING, POINT \\
241 Attribute & Name, Art, Quelle, Anmerkung, Stand, Verband, 241 Attribute & Name, Art, Quelle, Anmerkung, Stand, Verband,
242 km (alternativ: Deich\_km), Bereich, 242 km (alternativ: Deich\_km), Bereich,
243 Hoehe, Hoehe\_soll, WSP\_Bfg100, Bundesland 243 Hoehe, Hoehe\_soll, WSP\_Bfg100, Bundesland
244 (Teilweise auch alternative Schreibweisen unterstützt)\\ 244 (Teilweise auch alternative Schreibweisen unterstützt)\\
245 \end{tabular*} 245 \end{tabular*}
246 246
247 Das Attribut 'name' wird auf den Namen des Shapefiles gesetzt, 247 Das Attribut 'name' wird auf den Namen des Shapefiles gesetzt,
248 wenn kein Attribut 'Name' im Shapefile vorhanden ist. 248 wenn kein Attribut 'Name' im Shapefile vorhanden ist.
249 Das Feld 'kind\_id' wird per Default auf 2 (für Damm) gesetzt. 249 Das Feld 'kind\_id' wird per Default auf 2 (für Damm) gesetzt.
250 Wird ein Attribut 'ART' im Shapefile gefunden, 250 Wird ein Attribut 'ART' im Shapefile gefunden,
251 so wird 'kind\_id' entsprechend dieses Feldes gesetzt 251 so wird 'kind\_id' entsprechend dieses Feldes gesetzt
252 (1 für die Werte 'Durchlass', 'Rohr1', 'Rohr 1', 'Rohr 2', 252 (1 für die Werte 'Durchlass', 'Rohr1', 'Rohr 1', 'Rohr 2',
253 2 für die Werte 'Damm', 'Deich', 'Hochufer', 'Hauptdeich', 'Sommerdeich', 253 2 für die Werte 'Damm', 'Deich', 'Hochufer', 'Hauptdeich', 'Sommerdeich',
254 3 für den Wert 'Graben'). 254 3 für den Wert 'Graben').
255 Es wird versucht das Bundesland aus dem Dateinamen zu ermitteln, 255 Es wird versucht das Bundesland aus dem Dateinamen zu ermitteln,
256 wenn das Shapefile kein Attribut 'Bundesland' enthält. 256 wenn das Shapefile kein Attribut 'Bundesland' enthält.
261 \subsubsection{Buhnen} 261 \subsubsection{Buhnen}
262 \hspace{5mm} 262 \hspace{5mm}
263 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}} 263 \begin{tabular*}{155mm}[t]{l@{\extracolsep\fill}p{125mm}}
264 Pfad & Geodaesie/Bauwerke/Buhnen.shp \\ 264 Pfad & Geodaesie/Bauwerke/Buhnen.shp \\
265 Geometrie & POINT \\ 265 Geometrie & POINT \\
266 Attribute & station (alternativ: km, wsv-km), 266 Attribute & station (alternativ: km, wsv-km),
267 z (alternativ: Hoehe, Höhe, m+NHN) \\ 267 z (alternativ: Hoehe, Höhe, m+NHN) \\
268 \end{tabular*} 268 \end{tabular*}
269 269
270 Das Attribut 'kind\_id' wird für 270 Das Attribut 'kind\_id' wird für
271 Buhnenkopf (\textit{bkl, bkr, bk}) 0, 271 Buhnenkopf (\textit{bkl, bkr, bk}) 0,
272 für Buhnenfuß (\textit{bfl, bfr, bf}) 1 und 272 für Buhnenfuß (\textit{bfl, bfr, bf}) 1 und
273 für Buhnenwurzel (\textit{bwl, bwr, bw}) 2 gesetzt, 273 für Buhnenwurzel (\textit{bwl, bwr, bw}) 2 gesetzt,
274 274
275 \subsubsection{Stationierung} 275 \subsubsection{Stationierung}
314 Attribut & Projektion, Höhenstatus, Format, Bruchkanten, 314 Attribut & Projektion, Höhenstatus, Format, Bruchkanten,
315 Auflösung, SRID, Pfad\_Bestand, 315 Auflösung, SRID, Pfad\_Bestand,
316 km\_von, km\_bis, Jahr\_von, Jahr\_bis \\ 316 km\_von, km\_bis, Jahr\_von, Jahr\_bis \\
317 \end{tabular*} 317 \end{tabular*}
318 318
319 Aus der Spalte 'Gewässer' in DGMs.csv wird entnommen, 319 Aus der Spalte 'Gewässer' in DGMs.csv wird entnommen,
320 für welches Gewässer das angegebene DGM verwendet wird. 320 für welches Gewässer das angegebene DGM verwendet wird.
321 Die Spalte muss daher den exakt gleichen Namen enthalten 321 Die Spalte muss daher den exakt gleichen Namen enthalten
322 wie in der *.gew-Datei des Gewässers angegeben 322 wie in der *.gew-Datei des Gewässers angegeben
323 (siehe auch Kapitel \ref{start-hydr}). 323 (siehe auch Kapitel \ref{start-hydr}).
324 Die eigentlichen Geo-Daten der DGM werden nicht in die Datenbank importiert. 324 Die eigentlichen Geo-Daten der DGM werden nicht in die Datenbank importiert.
325 Diese werden von der Anwendung Dive4Elements River aus dem Dateisystem geholt. 325 Diese werden von der Anwendung Dive4Elements River aus dem Dateisystem geholt.
326 326
327 \subsection{Konfiguration} 327 \subsection{Konfiguration}
332 332
333 \textbf{HOST} 333 \textbf{HOST}
334 \\Der Host der Datenbank. 334 \\Der Host der Datenbank.
335 335
336 \textbf{BACKEND\_NAME} 336 \textbf{BACKEND\_NAME}
337 \\Der Name der Datenbank Instanz. 337 \\Der Name der Datenbank Instanz.
338 Beispielsweise \textit{XE} bei einer Oracle XE Instanz. 338 Beispielsweise \textit{XE} bei einer Oracle XE Instanz.
339 339
340 \textbf{USER} 340 \textbf{USER}
341 \\Der Nutzer, der zum Verbinden zur Datenbank verwendet wird. 341 \\Der Nutzer, der zum Verbinden zur Datenbank verwendet wird.
342 342

http://dive4elements.wald.intevation.org