diff --git a/analysers/Analyser_Osmosis.py b/analysers/Analyser_Osmosis.py index eed6e9310..51e3c2e6c 100644 --- a/analysers/Analyser_Osmosis.py +++ b/analysers/Analyser_Osmosis.py @@ -204,6 +204,34 @@ class Analyser_Osmosis(Analyser): CREATE INDEX idx_multipolygons_poly_proj ON {0}.multipolygons USING gist(poly_proj); CREATE INDEX idx_multipolygons_tags ON {0}.multipolygons USING gist (tags); ANALYZE {0}.multipolygons; +""" + + sql_create_polygons = """ +CREATE UNLOGGED TABLE {0}.polygons AS +SELECT + 'R' AS type, + * +FROM + {0}.multipolygons +UNION ALL +SELECT + 'W' AS type, + id, + tags, + CASE WHEN ST_IsValid(linestring) = 't' AND ST_IsSimple(linestring) = 't' AND ST_IsValid(ST_MakePolygon(ST_Transform(linestring, {1}))) THEN ST_MakePolygon(linestring) ELSE NULL END AS poly, + CASE WHEN ST_IsValid(linestring) = 't' AND ST_IsSimple(linestring) = 't' AND ST_IsValid(ST_MakePolygon(ST_Transform(linestring, {1}))) THEN ST_MakePolygon(ST_Transform(linestring, {1})) ELSE NULL END AS poly_proj, + true AS is_valid +FROM + ways +WHERE + tags != ''::hstore AND + is_polygon +; + +CREATE INDEX idx_polygons ON {0}.polygons USING gist(poly); +CREATE INDEX idx_polygons_proj ON {0}.polygons USING gist(poly_proj); +CREATE INDEX idx_polygons_tags ON {0}.polygons USING gist(tags); +ANALYZE {0}.polygons; """ sql_create_buildings = """ @@ -368,6 +396,12 @@ def requires_tables_build(self, tables): elif table == 'touched_multipolygons': self.requires_tables_build(['multipolygons']) self.create_view_touched('multipolygons', 'R') + elif table == 'polygons': + self.requires_tables_build(["multipolygons"]) + self.giscurs.execute(self.sql_create_polygons.format(self.config.db_schema.split(',')[0], self.config.options.get("proj"))) + elif table == 'touched_polygons': + self.requires_tables_build(["polygons"]) + self.create_view_touched('polygons', 'W') elif table == 'buildings': self.giscurs.execute(self.sql_create_buildings.format(self.config.db_schema.split(',')[0], self.config.options.get("proj"))) elif table == 'touched_buildings':