Included in this release are Postgres 9.1 and PostGIS 1.5.3. Installation of the following packages is recommended by https://gist.github.com/2589641
sudo apt-get -y install postgis postgresql-9.1 postgresql-server-dev-9.1 postgresql-contrib-9.1 postgis gdal-bin binutils libgeos-3.2.2 libgeos-c1 libgeos-dev libgdal1-dev libxml2 libxml2-dev libxml2-dev checkinstall proj libpq-dev postgresql-9.1-postgis
CREATE DATABASE dbname; \CONNECT dbname CREATE extension postgis;
To allow for easy dumping of the database it is a good idea to leave PostGIS-related tables in the public
-schema and put all your real data into an extra schema, e.g. data
.
Such a PostGIS-free-dump can then be used to restore (import) the data into a database with a newer version of PostGIS.
\c dbname CREATE SCHEMA myschena AUTHORIZATION owner; ALTER DATABASE dbname SET search_path=myschena,public;
Now all newly created tables will automatically belong to the schema data
.
As noted before, only export your data, not tables belonging to PostGIS. -Fc
stands for the custom format, which is already compressed.
pg_dump -t "data.*" -Fc dbname > "$(date +%Y-%m-%d)_dbname.dmp"
To import a dump first create a PostGIS-enabled database as described above.
Then import the dump:
pg_restore -Fc -d dbname dumpname.dmp
In the case that the dump only contained non-PostGIS tables the import should work without errors and you are finished.
Otherwise, there will be many errors, which hopefully have no bad effect.
In that case, use this script to set the schema of all non-PostGIS tables to data
to make a clean dump next time:
DO $$ DECLARE ROW record; BEGIN FOR ROW IN SELECT tablename FROM pg_tables WHERE schemaname = 'public' AND ( quote_ident(tablename) NOT IN ('geography_columns', 'geometry_columns', 'spatial_ref_sys')) LOOP EXECUTE 'ALTER TABLE public.' || quote_ident(ROW.tablename) || ' SET SCHEMA myschema;'; END LOOP; END; $$; DO $$ DECLARE ROW record; BEGIN FOR ROW IN SELECT viewname FROM pg_views WHERE schemaname = 'public' AND ( quote_ident(viewname) NOT IN ('geography_columns', 'geometry_columns', 'spatial_ref_sys')) LOOP EXECUTE 'ALTER VIEW public.' || quote_ident(ROW.viewname) || ' SET SCHEMA myschema;'; END LOOP; END; $$;
Unless noted otherwise, WGS84 is assumed (SRID 4326)
In table spatial_ref_sys, all tables containing PostGIS types are listed. To refresh this cache:
SELECT populate_Geometry_columns();
SELECT AddGeometryColumn('myschema', 'mytable', 'the_geom', 4326, 'POINT', 2) ;
UPDATE mytable SET the_geom = ST_SetSRID(ST_MakePoint(longitude,latitude),4326);
Building a FeatureCollection (docs, code snippet):
SELECT json_build_object( 'type', 'FeatureCollection', 'crs', json_build_object( 'type', 'name', 'properties', json_build_object( 'name', 'EPSG:4326' ) ), 'features', json_agg( json_build_object( 'type', 'Feature', 'id', id, 'geometry', ST_AsGeoJSON(the_geom)::json, 'properties', json_build_object( 'name', name, 'frc', frc, 'fromjunction', fromjunction, 'tojunction', tojunction, ) ) ) ) FROM roadmap_table;
SELECT link_id FROM my_links WHERE ST_INTERSECTS(the_geom,ST_GeomFromText('POLYGON( (16.37856 48.21199,16.38611 48.21143, 16.37563 48.19879,16.36826 48.20036 , 16.37856 48.21199)) ',4326) )