[162] | 1 | |
---|
| 2 | -- ALKIS PostNAS 0.7 |
---|
| 3 | |
---|
| 4 | -- ====================================================== |
---|
| 5 | -- Zusammenfassung der Tabellen der tatsÀchlichen Nutzung |
---|
| 6 | -- ====================================================== |
---|
| 7 | |
---|
| 8 | -- Um bei einer Feature.Info (Welche Nutzung an dieser Stelle?) |
---|
| 9 | -- oder einer Verschneidung (Welche Nutzungen auf dem FlurstÃŒck?) |
---|
| 10 | -- nicht 26 verschiedene Tabellen abfragen zu mÃŒssen, werden die wichtigsten |
---|
| 11 | -- Felder dieser Tabellen zusammen gefasst. |
---|
| 12 | |
---|
| 13 | -- Teil 1: Anlegen der Tabellen |
---|
| 14 | |
---|
| 15 | -- Stand |
---|
| 16 | |
---|
| 17 | -- 2012-02-10 PostNAS 07, Umbenennung |
---|
[298] | 18 | -- 2013-11-15 In nutzung_class.class können NULL-Werte auftreten. |
---|
| 19 | -- 2013-11-26 NULL wird durch Zahl "0" ersetzt, "NOT NULL" wieder aktivieren |
---|
[330] | 20 | -- 2014-08-26 erweiterte gml_id (wie in den primÀren Tabellen) |
---|
[162] | 21 | |
---|
| 22 | SET client_encoding = 'UTF-8'; |
---|
| 23 | |
---|
| 24 | -- Alles auf Anfang! |
---|
[330] | 25 | /* |
---|
| 26 | DROP TABLE nutzung; |
---|
| 27 | DROP TABLE nutzung_class; |
---|
| 28 | DROP TABLE nutzung_meta; |
---|
| 29 | */ |
---|
[162] | 30 | |
---|
| 31 | -- Meta-Informationen ueber die Zusammenfassung und Gruppierung |
---|
| 32 | -- ------------------------------------------------------------ |
---|
| 33 | CREATE TABLE nutzung_meta ( |
---|
| 34 | nutz_id integer NOT NULL, |
---|
| 35 | gruppe character varying(30), |
---|
| 36 | source_table character varying(50), |
---|
| 37 | title character varying(50), |
---|
| 38 | fldclass character varying(30), |
---|
| 39 | fldinfo character varying(30), |
---|
| 40 | CONSTRAINT nutzung_meta_pk PRIMARY KEY (nutz_id) |
---|
| 41 | ); |
---|
| 42 | |
---|
| 43 | COMMENT ON TABLE nutzung_meta IS 'Gruppierung und Indizierung der zusammen gefassten Nutzungsarten in der Tabelle "nutzung".'; |
---|
| 44 | COMMENT ON COLUMN nutzung_meta.nutz_id IS 'Index fuer die Quell-Tabelle bei der Zusammenfassung in der Tabelle "nutzung".'; |
---|
| 45 | COMMENT ON COLUMN nutzung_meta.source_table IS 'Name der importierten Tabelle aus PostNAS.'; |
---|
| 46 | COMMENT ON COLUMN nutzung_meta.gruppe IS 'Objektartengruppe, Gruppierung der Nutzungsart.'; |
---|
| 47 | COMMENT ON COLUMN nutzung_meta.title IS 'Vorzeigbare Bezeichnung der Nutzungsartentabelle.'; |
---|
| 48 | COMMENT ON COLUMN nutzung_meta.fldclass IS 'Name des Feldes aus "source_table", das in Feld "nutzung.class" kopiert wird.'; |
---|
| 49 | COMMENT ON COLUMN nutzung_meta.fldinfo IS 'Name des Feldes aus "source_table", das in Feld "nutzung.info" kopiert wird.'; |
---|
| 50 | |
---|
| 51 | |
---|
| 52 | -- Alle Abschnitte der "tatsÀchlichen Nutzung" vereinigt in einer Tabelle |
---|
| 53 | -- Sie sind dann mit einem gemeinsamen Geometrie-Index mit einer SQL-Abfrage auffindbar. |
---|
[330] | 54 | -- Dies ist die förderlich fÌr eine performante Auskunft. |
---|
[162] | 55 | |
---|
| 56 | CREATE TABLE nutzung ( |
---|
[330] | 57 | gml_id character varying NOT NULL, |
---|
| 58 | beginnt character(20), -- mehrfache gml_id eindeutig machen |
---|
| 59 | -- endet character(20), -- nur "ended IS NULL" kopieren |
---|
| 60 | nutz_id integer, |
---|
| 61 | class integer NOT NULL, -- NULL-Werte der Quelltabelle durch den num. Wert 0 ersetzen |
---|
| 62 | info integer, |
---|
| 63 | zustand integer, |
---|
| 64 | "name" character varying, |
---|
| 65 | bezeichnung character varying, |
---|
| 66 | CONSTRAINT nutzung_pk PRIMARY KEY (gml_id, beginnt), |
---|
| 67 | CONSTRAINT nutzung_meta_id FOREIGN KEY (nutz_id) |
---|
[162] | 68 | REFERENCES nutzung_meta (nutz_id) MATCH SIMPLE |
---|
| 69 | ON UPDATE NO ACTION ON DELETE CASCADE |
---|
| 70 | ) |
---|
| 71 | WITH (OIDS=FALSE); |
---|
| 72 | |
---|
[178] | 73 | |
---|
[162] | 74 | SELECT AddGeometryColumn('nutzung','wkb_geometry','25832','POLYGON',2); |
---|
[330] | 75 | -- Vereinzelt auch vorkommende MULTIPOLYGON |
---|
[162] | 76 | |
---|
| 77 | -- 'class' ist nur innerhalb einer Gruppe ein sinvoller Index |
---|
| 78 | CREATE INDEX idx_nutz_cls ON nutzung USING btree (nutz_id, class); |
---|
| 79 | |
---|
| 80 | -- Geometrischer Index fÌr die rÀumliche Suche |
---|
| 81 | CREATE INDEX nutzung_geom_idx ON nutzung USING gist (wkb_geometry); |
---|
| 82 | |
---|
[178] | 83 | COMMENT ON TABLE nutzung IS 'Zusammenfassung von 26 Tabellen des Objektbereiches "TatsÀchliche Nutzung".'; |
---|
[162] | 84 | COMMENT ON COLUMN nutzung.gml_id IS 'Identifikator, global eindeutig'; |
---|
| 85 | COMMENT ON COLUMN nutzung.nutz_id IS 'Index fuer die Quell-Tabelle bei der Zusammenfassung in der Tabelle "nutzung".'; |
---|
| 86 | COMMENT ON COLUMN nutzung.class IS 'Klassifizierung innerhalb der Nutzung. Aus verschiedenen Feldern importiert. Siehe "nutzung_meta.fldclass".'; |
---|
| 87 | COMMENT ON COLUMN nutzung.info IS 'Weitere verschlÃŒsselte Information zur Nutzung. Aus verschiedenen Feldern importiert. Siehe "nutzung_meta.fldinfo".'; |
---|
| 88 | COMMENT ON COLUMN nutzung.name IS 'NAM Eigenname'; |
---|
| 89 | COMMENT ON COLUMN nutzung.bezeichnung IS 'weitere unverschlÃŒsselte Information wie Zweitname, Bezeichnung, fachliche Nummerierung usw.'; |
---|
| 90 | COMMENT ON COLUMN nutzung.zustand IS 'ZUS "Zustand" beschreibt, ob der Abschnitt ungenutzt ist.'; |
---|
| 91 | |
---|
| 92 | |
---|
| 93 | -- Schluesseltabelle: classes innerhalb einer Nutzungsart. |
---|
[298] | 94 | -- Wird nicht aus NAS geladen sondern durch das manuell zu pflegende Script "nutzungsart_metadaten.sql" |
---|
[162] | 95 | CREATE TABLE nutzung_class ( |
---|
| 96 | nutz_id integer NOT NULL, |
---|
[298] | 97 | class integer, -- NOT NULL, |
---|
[162] | 98 | label character varying(100), |
---|
| 99 | blabla character varying(1000), |
---|
[298] | 100 | CONSTRAINT nutzung_class_pk PRIMARY KEY (nutz_id, class), |
---|
[162] | 101 | CONSTRAINT nutzung_class_id FOREIGN KEY (nutz_id) |
---|
| 102 | REFERENCES nutzung_meta (nutz_id) MATCH SIMPLE |
---|
| 103 | ON UPDATE NO ACTION ON DELETE CASCADE |
---|
| 104 | ); |
---|
| 105 | |
---|
[298] | 106 | COMMENT ON TABLE nutzung_class IS 'SchlÃŒsseltabelle. Feinere Klassifizierung der zusammen gefassten Nutzungsarten.'; |
---|
| 107 | COMMENT ON COLUMN nutzung_class.nutz_id IS 'Index fuer die Quell-Tabelle bei der Zusammenfassung in der Tabelle nutzung.'; |
---|
| 108 | COMMENT ON COLUMN nutzung_class.class IS 'Key, SchlÃŒsselwert oder NULL'; |
---|
| 109 | COMMENT ON COLUMN nutzung_class.label IS 'EntschlÃŒsselung. Art der Nutzung, Dies Feld soll in der Auskunft angezeigt werden.'; |
---|
| 110 | COMMENT ON COLUMN nutzung_class.blabla IS 'Weitere ErlÀuterungen und Definitionen dazu.'; |
---|
[162] | 111 | |
---|
[178] | 112 | |
---|
| 113 | -- Fehlersuche nach GDAL Patch #5444: |
---|
| 114 | -- Da nun gml_id nicht mehr PRIMARY KEY der Ausgangstabellen ist , kommt es auch zu Doppelbelegungen der Zusammenfassung. |
---|
| 115 | -- Diese FÀlle suchen. |
---|
| 116 | CREATE OR REPLACE VIEW nutzung_mehrfache_gml AS |
---|
[330] | 117 | SELECT a.gml_id, a.nutz_id, a.beginnt as beginnt1, b.beginnt as beginnt2 |
---|
[178] | 118 | FROM nutzung a |
---|
[330] | 119 | JOIN nutzung b ON a.gml_id = b.gml_id |
---|
[178] | 120 | WHERE a.beginnt < b.beginnt |
---|
| 121 | --LIMIT 100 |
---|
| 122 | ; |
---|
| 123 | |
---|
| 124 | -- Vorkommende Geometry-Typen |
---|
| 125 | |
---|
| 126 | -- SELECT a.gml_id, st_geometrytype(a.wkb_geometry) as geomtype ,a.artderbebauung, a.zustand, a.name, a.beginnt |
---|
| 127 | -- FROM ax_wohnbauflaeche a WHERE geometrytype(wkb_geometry) <> 'POLYGON'; |
---|
| 128 | |
---|
| 129 | -- SELECT a.gml_id, st_geometrytype(a.wkb_geometry) as geomtype ,a.artderbebauung, a.zustand, a.name, a.beginnt |
---|
| 130 | -- FROM ax_wohnbauflaeche a WHERE geometrytype(wkb_geometry) <> 'POLYGON'; |
---|
| 131 | |
---|
| 132 | -- Ergebnis: Ein MULTIPOLYGON |
---|
| 133 | -- Konsequenz: nur Polygone kopieren. |
---|
| 134 | |
---|
[162] | 135 | -- END -- |
---|