parent_place_id BIGINT DEFAULT NULL;
location RECORD;
parent RECORD;
- word_ids INTEGER[];
BEGIN
--DEBUG: RAISE WARNING 'finding street for % %', poi_osm_type, poi_osm_id;
END LOOP;
END LOOP;
- -- Check for addr:street attributes
- -- Note that addr:street links can only be indexed, once the street itself is indexed
- word_ids := word_ids_from_name(addr_street);
- IF word_ids is not null THEN
- SELECT place_id
- FROM getNearestNamedRoadFeature(poi_partition, near_centroid, word_ids)
- INTO parent_place_id;
- IF parent_place_id is not null THEN
- --DEBUG: RAISE WARNING 'Get parent form addr:street: %', parent.place_id;
- RETURN parent_place_id;
- END IF;
- END IF;
-
- -- Check for addr:place attributes.
- word_ids := word_ids_from_name(addr_place);
- IF word_ids is not null THEN
- SELECT place_id
- FROM getNearestNamedPlaceFeature(poi_partition, near_centroid, word_ids)
- INTO parent_place_id;
- IF parent_place_id is not null THEN
- --DEBUG: RAISE WARNING 'Get parent form addr:place: %', parent.place_id;
- RETURN parent_place_id;
- END IF;
+ parent_place_id := find_parent_for_address(addr_street, addr_place,
+ poi_partition, near_centroid);
+ IF parent_place_id is not null THEN
+ RETURN parent_place_id;
END IF;
IF poi_osm_type = 'N' THEN
WHERE make_standard_name(name->'name') = bnd_name
AND placex.rank_address = bnd.rank_address
AND placex.osm_type = 'N'
+ AND placex.rank_search < 26 -- needed to select the right index
AND st_covers(geometry, placex.geometry)
LOOP
--DEBUG: RAISE WARNING 'Found matching place node %', linkedPlacex.osm_id;
RETURN NULL;
END;
$$
-LANGUAGE plpgsql;
+LANGUAGE plpgsql STABLE;
CREATE OR REPLACE FUNCTION placex_insert()
RETURNS TRIGGER
RETURNS TRIGGER
AS $$
DECLARE
-
near_centroid GEOMETRY;
search_maxdistance FLOAT[];
address_havelevel BOOLEAN[];
i INTEGER;
- iMax FLOAT;
location RECORD;
- way RECORD;
- relation RECORD;
relation_members TEXT[];
addr_item RECORD;
search_diameter FLOAT;
search_prevdiameter FLOAT;
search_maxrank INTEGER;
address_maxrank INTEGER;
- address_street_word_id INTEGER;
address_street_word_ids INTEGER[];
parent_place_id_rank BIGINT;
IF NEW.address IS NOT NULL THEN
FOR addr_item IN SELECT * FROM each(NEW.address)
LOOP
- IF addr_item.key IN ('city', 'tiger:county', 'state', 'suburb', 'province', 'district', 'region', 'county', 'municipality', 'hamlet', 'village', 'subdistrict', 'town', 'neighbourhood', 'quarter', 'parish') THEN
- address_street_word_id := get_name_id(make_standard_name(addr_item.value));
- IF address_street_word_id IS NOT NULL AND NOT(ARRAY[address_street_word_id] <@ isin_tokens) THEN
- isin_tokens := isin_tokens || address_street_word_id;
+ IF addr_item.key IN ('city', 'tiger:county', 'state', 'suburb', 'province',
+ 'district', 'region', 'county', 'municipality',
+ 'hamlet', 'village', 'subdistrict', 'town',
+ 'neighbourhood', 'quarter', 'parish')
+ THEN
+ address_street_word_ids := word_ids_from_name(addr_item.value);
+ IF address_street_word_ids is not null THEN
+ isin_tokens := array_merge(isin_tokens, address_street_word_ids);
END IF;
IF NOT %REVERSE-ONLY% THEN
- address_street_word_id := get_word_id(make_standard_name(addr_item.value));
- IF address_street_word_id IS NOT NULL THEN
- nameaddress_vector := array_merge(nameaddress_vector, ARRAY[address_street_word_id]);
+ address_street_word_ids := addr_ids_from_name(addr_item.value);
+ IF address_street_word_ids is not null THEN
+ nameaddress_vector := array_merge(nameaddress_vector,
+ address_street_word_ids);
END IF;
END IF;
END IF;
isin := regexp_split_to_array(addr_item.value, E'[;,]');
IF array_upper(isin, 1) IS NOT NULL THEN
FOR i IN 1..array_upper(isin, 1) LOOP
- address_street_word_id := get_name_id(make_standard_name(isin[i]));
- IF address_street_word_id IS NOT NULL AND NOT(ARRAY[address_street_word_id] <@ isin_tokens) THEN
- isin_tokens := isin_tokens || address_street_word_id;
+ address_street_word_ids := word_ids_from_name(isin[i]);
+ IF address_street_word_ids is not null THEN
+ isin_tokens := array_merge(isin_tokens, address_street_word_ids);
END IF;
-- merge word into address vector
IF NOT %REVERSE-ONLY% THEN
- address_street_word_id := get_word_id(make_standard_name(isin[i]));
- IF address_street_word_id IS NOT NULL THEN
- nameaddress_vector := array_merge(nameaddress_vector, ARRAY[address_street_word_id]);
+ address_street_word_ids := addr_ids_from_name(isin[i]);
+ IF address_street_word_ids is not null THEN
+ nameaddress_vector := array_merge(nameaddress_vector,
+ address_street_word_ids);
END IF;
END IF;
END LOOP;