From: Brian Quinion Date: Thu, 26 Apr 2012 13:50:58 +0000 (-0700) Subject: Merge pull request #5 from mfn/improve_errmsg X-Git-Tag: v2.0.0~77^2~4 X-Git-Url: https://git.openstreetmap.org/nominatim.git/commitdiff_plain/b8db117bd0211cc974cb9e3468d431adb6da21c6?hp=fd3fcea539878b8f96cb9bcad51152459442ab48 Merge pull request #5 from mfn/improve_errmsg Do not swallow PEAR error during setup in import-data. --- diff --git a/sql/functions.sql b/sql/functions.sql index b248a46d..806e1566 100644 --- a/sql/functions.sql +++ b/sql/functions.sql @@ -1007,8 +1007,8 @@ BEGIN NEW.rank_search := 8; NEW.rank_address := NEW.rank_search; ELSEIF NEW.type in ('region') THEN - NEW.rank_search := 10; - NEW.rank_address := NEW.rank_search; + NEW.rank_search := 18; -- dropped from previous value of 10 + NEW.rank_address := 0; -- So badly miss-used that better to just drop it! ELSEIF NEW.type in ('county') THEN NEW.rank_search := 12; NEW.rank_address := NEW.rank_search; @@ -1532,14 +1532,14 @@ BEGIN -- not found one yet? how about doing a name search IF NEW.centroid IS NULL THEN - FOR linkedPlacex IN select placex.* from search_name join placex using (place_id) WHERE - search_name.name_vector @> ARRAY[getorcreate_name_id(make_standard_name(NEW.name->'name'))] - AND search_name.search_rank = NEW.rank_search - AND search_name.place_id != NEW.place_id + FOR linkedPlacex IN select placex.* from placex WHERE + make_standard_name(name->'name') = make_standard_name(NEW.name->'name') + AND placex.rank_search = NEW.rank_search + AND placex.place_id != NEW.place_id AND osm_type = 'N' - AND NEW.name->'name' = placex.name->'name' AND st_contains(NEW.geometry, placex.geometry) LOOP + -- If we don't already have one use this as the centre point of the geometry IF NEW.centroid IS NULL THEN NEW.centroid := coalesce(linkedPlacex.centroid,st_centroid(linkedPlacex.geometry)); diff --git a/sql/indices.src.sql b/sql/indices.src.sql index 05cbd90d..57a6cdd7 100644 --- a/sql/indices.src.sql +++ b/sql/indices.src.sql @@ -15,7 +15,7 @@ CREATE INDEX idx_placex_pendingsector ON placex USING BTREE (rank_search,geometr CREATE INDEX idx_placex_parent_place_id ON placex USING BTREE (parent_place_id) where parent_place_id IS NOT NULL; CREATE INDEX idx_placex_interpolation ON placex USING BTREE (geometry_sector) where indexed_status > 0 and class='place' and type='houses'; CREATE INDEX idx_placex_sector ON placex USING BTREE (geometry_sector,rank_address,osm_type,osm_id); - +CREATE INDEX idx_placex_adminname on placex USING BTREE (make_standard_name(name->'name'),rank_search) WHERE osm_type='N' and rank_search < 26; CREATE INDEX idx_location_area_country_place_id ON location_area_country USING BTREE (place_id); CREATE INDEX idx_search_name_country_centroid ON search_name_country USING GIST (centroid);