]> git.openstreetmap.org Git - nominatim.git/blob - sql/partition-tables.src.sql
add script for detailed explaing of indexing trigger
[nominatim.git] / sql / partition-tables.src.sql
1 drop table IF EXISTS search_name_blank CASCADE;
2 CREATE TABLE search_name_blank (
3   place_id BIGINT,
4   search_rank smallint,
5   address_rank smallint,
6   name_vector integer[],
7   centroid GEOMETRY(Geometry, 4326)
8   );
9
10
11 -- start
12 CREATE TABLE location_area_large_-partition- () INHERITS (location_area_large) {ts:address-data};
13 CREATE INDEX idx_location_area_large_-partition-_place_id ON location_area_large_-partition- USING BTREE (place_id) {ts:address-index};
14 CREATE INDEX idx_location_area_large_-partition-_geometry ON location_area_large_-partition- USING GIST (geometry) {ts:address-index};
15
16 CREATE TABLE search_name_-partition- () INHERITS (search_name_blank) {ts:address-data};
17 CREATE INDEX idx_search_name_-partition-_place_id ON search_name_-partition- USING BTREE (place_id) {ts:address-index};
18 CREATE INDEX idx_search_name_-partition-_centroid_street ON search_name_-partition- USING GIST (centroid) {ts:address-index} where search_rank between 26 and 27;
19 CREATE INDEX idx_search_name_-partition-_centroid_place ON search_name_-partition- USING GIST (centroid) {ts:address-index} where search_rank between 2 and 25;
20
21 DROP TABLE IF EXISTS location_road_-partition-;
22 CREATE TABLE location_road_-partition- (
23   place_id BIGINT,
24   partition SMALLINT,
25   country_code VARCHAR(2),
26   geometry GEOMETRY(Geometry, 4326)
27   ) {ts:address-data};
28 CREATE INDEX idx_location_road_-partition-_geometry ON location_road_-partition- USING GIST (geometry) {ts:address-index};
29 CREATE INDEX idx_location_road_-partition-_place_id ON location_road_-partition- USING BTREE (place_id) {ts:address-index};
30
31 -- end