mirror of
https://github.com/osm-search/Nominatim.git
synced 2024-11-26 13:27:52 +03:00
Merge pull request #2678 from lonvia/address-part-order
Change selection of primary address part for ways that cross boundaries
This commit is contained in:
commit
de828b723e
@ -39,7 +39,10 @@ BEGIN
|
||||
END
|
||||
$$ LANGUAGE plpgsql IMMUTABLE;
|
||||
|
||||
create or replace function getNearFeatures(in_partition INTEGER, feature GEOMETRY, maxrank INTEGER) RETURNS setof nearfeaturecentr AS $$
|
||||
CREATE OR REPLACE function getNearFeatures(in_partition INTEGER, feature GEOMETRY,
|
||||
feature_centroid GEOMETRY,
|
||||
maxrank INTEGER)
|
||||
RETURNS setof nearfeaturecentr AS $$
|
||||
DECLARE
|
||||
r nearfeaturecentr%rowtype;
|
||||
BEGIN
|
||||
@ -48,7 +51,11 @@ BEGIN
|
||||
IF in_partition = {{ partition }} THEN
|
||||
FOR r IN
|
||||
SELECT place_id, keywords, rank_address, rank_search,
|
||||
min(ST_Distance(feature, centroid)) as distance,
|
||||
CASE WHEN isguess THEN ST_Distance(feature, centroid)
|
||||
ELSE min(ST_Distance(feature_centroid, geometry))
|
||||
-- tie breaker when distance is the same (i.e. way is on boundary)
|
||||
+ 0.00001 * ST_Distance(feature, centroid)
|
||||
END as distance,
|
||||
isguess, postcode, centroid
|
||||
FROM location_area_large_{{ partition }}
|
||||
WHERE geometry && feature
|
||||
|
@ -449,6 +449,7 @@ CREATE OR REPLACE FUNCTION insert_addresslines(obj_place_id BIGINT,
|
||||
maxrank SMALLINT,
|
||||
token_info JSONB,
|
||||
geometry GEOMETRY,
|
||||
centroid GEOMETRY,
|
||||
country TEXT,
|
||||
OUT parent_place_id BIGINT,
|
||||
OUT postcode TEXT,
|
||||
@ -511,7 +512,7 @@ BEGIN
|
||||
END LOOP;
|
||||
|
||||
FOR location IN
|
||||
SELECT * FROM getNearFeatures(partition, geometry, maxrank)
|
||||
SELECT * FROM getNearFeatures(partition, geometry, centroid, maxrank)
|
||||
WHERE not addr_place_ids @> ARRAY[place_id]
|
||||
ORDER BY rank_address, isguess asc,
|
||||
distance *
|
||||
@ -1106,7 +1107,8 @@ BEGIN
|
||||
END IF;
|
||||
|
||||
SELECT * FROM insert_addresslines(NEW.place_id, NEW.partition, max_rank,
|
||||
NEW.token_info, geom, NEW.country_code)
|
||||
NEW.token_info, geom, NEW.centroid,
|
||||
NEW.country_code)
|
||||
INTO NEW.parent_place_id, NEW.postcode, nameaddress_vector;
|
||||
|
||||
{% if debug %}RAISE WARNING 'RETURN insert_addresslines: %, %, %', NEW.parent_place_id, NEW.postcode, nameaddress_vector;{% endif %}
|
||||
|
@ -34,7 +34,7 @@ BEGIN
|
||||
NEW.parent_place_id = 0;
|
||||
FOR location IN
|
||||
SELECT place_id
|
||||
FROM getNearFeatures(partition, NEW.geometry, NEW.rank_search)
|
||||
FROM getNearFeatures(partition, NEW.geometry, NEW.geometry, NEW.rank_search)
|
||||
WHERE NOT isguess ORDER BY rank_address DESC, distance asc LIMIT 1
|
||||
LOOP
|
||||
NEW.parent_place_id = location.place_id;
|
||||
|
Loading…
Reference in New Issue
Block a user