mirror of
https://github.com/osm-search/Nominatim.git
synced 2026-02-26 11:08:13 +00:00
use rank_address for linking places and boundaries
This manages to match up a lot more places and boundaries below city level.
This commit is contained in:
@@ -1540,7 +1540,7 @@ BEGIN
|
|||||||
-- For an admin centre we also want a name match - still not perfect, for example 'new york, new york'
|
-- For an admin centre we also want a name match - still not perfect, for example 'new york, new york'
|
||||||
-- But that can be fixed by explicitly setting the label in the data
|
-- But that can be fixed by explicitly setting the label in the data
|
||||||
IF make_standard_name(NEW.name->'name') = make_standard_name(linkedPlacex.name->'name')
|
IF make_standard_name(NEW.name->'name') = make_standard_name(linkedPlacex.name->'name')
|
||||||
AND NEW.rank_search = linkedPlacex.rank_search THEN
|
AND NEW.rank_address = linkedPlacex.rank_address THEN
|
||||||
|
|
||||||
|
|
||||||
-- If we don't already have one use this as the centre point of the geometry
|
-- If we don't already have one use this as the centre point of the geometry
|
||||||
@@ -1577,7 +1577,7 @@ BEGIN
|
|||||||
|
|
||||||
FOR linkedPlacex IN select placex.* from placex WHERE
|
FOR linkedPlacex IN select placex.* from placex WHERE
|
||||||
make_standard_name(name->'name') = make_standard_name(NEW.name->'name')
|
make_standard_name(name->'name') = make_standard_name(NEW.name->'name')
|
||||||
AND placex.rank_search = NEW.rank_search
|
AND placex.rank_address = NEW.rank_address
|
||||||
AND placex.place_id != NEW.place_id
|
AND placex.place_id != NEW.place_id
|
||||||
AND placex.osm_type = 'N'::char(1) AND placex.rank_search < 26
|
AND placex.osm_type = 'N'::char(1) AND placex.rank_search < 26
|
||||||
AND st_covers(NEW.geometry, placex.geometry)
|
AND st_covers(NEW.geometry, placex.geometry)
|
||||||
|
|||||||
Reference in New Issue
Block a user