X-Git-Url: https://git.openstreetmap.org./nominatim.git/blobdiff_plain/e7b738fe35a2ec13efdc22c9f068c477182da6c3..f0088ca2be3bafc77993558d794715c652eb7b25:/docs/admin/Migration.md diff --git a/docs/admin/Migration.md b/docs/admin/Migration.md index 0a522488..012c58b3 100644 --- a/docs/admin/Migration.md +++ b/docs/admin/Migration.md @@ -6,6 +6,51 @@ to newer versions of Nominatim. SQL statements should be executed from the postgres commandline. Execute `psql nominiatim` to enter command line mode. +## 3.1.0 -> 3.2.0 + +### New reverse algorithm + +The reverse algorithm has changed and requires new indexes. Run the following +SQL statements to create the indexes: + +``` +CREATE INDEX idx_placex_geometry_reverse_lookupPoint + ON placex USING gist (geometry) + WHERE (name is not null or housenumber is not null or rank_address between 26 and 27) + AND class not in ('railway','tunnel','bridge','man_made') + AND rank_address >= 26 AND indexed_status = 0 AND linked_place_id is null; +CREATE INDEX idx_placex_geometry_reverse_lookupPolygon + ON placex USING gist (geometry) + WHERE St_GeometryType(geometry) in ('ST_Polygon', 'ST_MultiPolygon') + AND rank_address between 4 and 25 AND type != 'postcode' + AND name is not null AND indexed_status = 0 AND linked_place_id is null; +CREATE INDEX idx_placex_geometry_reverse_placeNode + ON placex USING gist (geometry) + WHERE osm_type = 'N' AND rank_search between 5 and 25 + AND class = 'place' AND type != 'postcode' + AND name is not null AND indexed_status = 0 AND linked_place_id is null; +``` + +You also need to grant the website user access to the `country_osm_grid` table: + +``` +GRANT SELECT ON table country_osm_grid to "www-user"; +``` + +Replace the `www-user` with the user name of your website server if necessary. + +You can now drop the unused indexes: + +``` +DROP INDEX idx_placex_reverse_geometry; +``` + +Finally, update all SQL functions: + +```sh +./utils/setup.php --create-functions --enable-diff-updates --create-partition-functions +``` + ## 3.0.0 -> 3.1.0 ### Postcode Table