mirror of
https://github.com/osm-search/Nominatim.git
synced 2026-02-26 11:08:13 +00:00
Merge pull request #2818 from lonvia/better-geometry-index
Add index for lookup of addressable areas
This commit is contained in:
@@ -874,8 +874,9 @@ BEGIN
|
|||||||
FROM placex,
|
FROM placex,
|
||||||
LATERAL compute_place_rank(country_code, 'A', class, type,
|
LATERAL compute_place_rank(country_code, 'A', class, type,
|
||||||
admin_level, False, null) prank
|
admin_level, False, null) prank
|
||||||
WHERE class = 'place' and rank_address < 24
|
WHERE class = 'place' and rank_address between 1 and 23
|
||||||
and prank.address_rank >= NEW.rank_address
|
and prank.address_rank >= NEW.rank_address
|
||||||
|
and ST_GeometryType(geometry) in ('ST_Polygon','ST_MultiPolygon') -- select right index
|
||||||
and geometry && NEW.geometry
|
and geometry && NEW.geometry
|
||||||
and geometry ~ NEW.geometry -- needed because ST_Relate does not do bbox cover test
|
and geometry ~ NEW.geometry -- needed because ST_Relate does not do bbox cover test
|
||||||
and ST_Relate(geometry, NEW.geometry, 'T*T***FF*') -- contains but not equal
|
and ST_Relate(geometry, NEW.geometry, 'T*T***FF*') -- contains but not equal
|
||||||
@@ -896,6 +897,8 @@ BEGIN
|
|||||||
LATERAL compute_place_rank(country_code, 'A', class, type,
|
LATERAL compute_place_rank(country_code, 'A', class, type,
|
||||||
admin_level, False, null) prank
|
admin_level, False, null) prank
|
||||||
WHERE prank.address_rank < 24
|
WHERE prank.address_rank < 24
|
||||||
|
and rank_address between 1 and 25 -- select right index
|
||||||
|
and ST_GeometryType(geometry) in ('ST_Polygon','ST_MultiPolygon') -- select right index
|
||||||
and prank.address_rank >= NEW.rank_address
|
and prank.address_rank >= NEW.rank_address
|
||||||
and geometry && NEW.geometry
|
and geometry && NEW.geometry
|
||||||
and geometry ~ NEW.geometry -- needed because ST_Relate does not do bbox cover test
|
and geometry ~ NEW.geometry -- needed because ST_Relate does not do bbox cover test
|
||||||
@@ -916,6 +919,8 @@ BEGIN
|
|||||||
LATERAL compute_place_rank(country_code, 'A', class, type,
|
LATERAL compute_place_rank(country_code, 'A', class, type,
|
||||||
admin_level, False, null) prank
|
admin_level, False, null) prank
|
||||||
WHERE osm_type = 'R'
|
WHERE osm_type = 'R'
|
||||||
|
and rank_address between 1 and 25 -- select right index
|
||||||
|
and ST_GeometryType(geometry) in ('ST_Polygon','ST_MultiPolygon') -- select right index
|
||||||
and ((class = 'place' and prank.address_rank = NEW.rank_address)
|
and ((class = 'place' and prank.address_rank = NEW.rank_address)
|
||||||
or (class = 'boundary' and rank_address = NEW.rank_address))
|
or (class = 'boundary' and rank_address = NEW.rank_address))
|
||||||
and geometry && NEW.centroid and _ST_Covers(geometry, NEW.centroid)
|
and geometry && NEW.centroid and _ST_Covers(geometry, NEW.centroid)
|
||||||
|
|||||||
@@ -162,12 +162,16 @@ CREATE INDEX idx_placex_osmid ON placex USING BTREE (osm_type, osm_id) {{db.tabl
|
|||||||
CREATE INDEX idx_placex_linked_place_id ON placex USING BTREE (linked_place_id) {{db.tablespace.address_index}} WHERE linked_place_id IS NOT NULL;
|
CREATE INDEX idx_placex_linked_place_id ON placex USING BTREE (linked_place_id) {{db.tablespace.address_index}} WHERE linked_place_id IS NOT NULL;
|
||||||
CREATE INDEX idx_placex_rank_search ON placex USING BTREE (rank_search, geometry_sector) {{db.tablespace.address_index}};
|
CREATE INDEX idx_placex_rank_search ON placex USING BTREE (rank_search, geometry_sector) {{db.tablespace.address_index}};
|
||||||
CREATE INDEX idx_placex_geometry ON placex USING GIST (geometry) {{db.tablespace.search_index}};
|
CREATE INDEX idx_placex_geometry ON placex USING GIST (geometry) {{db.tablespace.search_index}};
|
||||||
|
CREATE INDEX idx_placex_geometry_address_area_candidates ON placex
|
||||||
|
USING gist (geometry) {{db.tablespace.address_index}}
|
||||||
|
WHERE rank_address between 1 and 25
|
||||||
|
and ST_GeometryType(geometry) in ('ST_Polygon','ST_MultiPolygon');
|
||||||
CREATE INDEX idx_placex_geometry_buildings ON placex
|
CREATE INDEX idx_placex_geometry_buildings ON placex
|
||||||
USING {{postgres.spgist_geom}} (geometry) {{db.tablespace.search_index}}
|
USING {{postgres.spgist_geom}} (geometry) {{db.tablespace.address_index}}
|
||||||
WHERE address is not null and rank_search = 30
|
WHERE address is not null and rank_search = 30
|
||||||
and ST_GeometryType(geometry) in ('ST_Polygon','ST_MultiPolygon');
|
and ST_GeometryType(geometry) in ('ST_Polygon','ST_MultiPolygon');
|
||||||
CREATE INDEX idx_placex_geometry_placenode ON placex
|
CREATE INDEX idx_placex_geometry_placenode ON placex
|
||||||
USING {{postgres.spgist_geom}} (geometry) {{db.tablespace.search_index}}
|
USING {{postgres.spgist_geom}} (geometry) {{db.tablespace.address_index}}
|
||||||
WHERE osm_type = 'N' and rank_search < 26
|
WHERE osm_type = 'N' and rank_search < 26
|
||||||
and class = 'place' and type != 'postcode' and linked_place_id is null;
|
and class = 'place' and type != 'postcode' and linked_place_id is null;
|
||||||
CREATE INDEX idx_placex_wikidata on placex USING BTREE ((extratags -> 'wikidata')) {{db.tablespace.address_index}} WHERE extratags ? 'wikidata' and class = 'place' and osm_type = 'N' and rank_search < 26;
|
CREATE INDEX idx_placex_wikidata on placex USING BTREE ((extratags -> 'wikidata')) {{db.tablespace.address_index}} WHERE extratags ? 'wikidata' and class = 'place' and osm_type = 'N' and rank_search < 26;
|
||||||
|
|||||||
Reference in New Issue
Block a user