Примеры использования инструментов PostGIS: различия между версиями

Материал из GIS-Lab
Перейти к навигации Перейти к поиску
Строка 26: Строка 26:
<pre>ALTER DATABASE testdb OWNER TO admin;</pre>
<pre>ALTER DATABASE testdb OWNER TO admin;</pre>


Добавление функций PostGIS
Добавление функций PostGIS и систем координат (нужно знать, куда установился postgis):
<pre>psql -U pgsql -d testdb -f /usr/local/share/postgis/postgis.sql
<pre>psql -U pgsql -d testdb -f /usr/local/share/postgis/postgis.sql
psql -U pgsql -d testdb -f /usr/local/share/postgis/spatial_ref_sys.sql</pre>
psql -U pgsql -d testdb -f /usr/local/share/postgis/spatial_ref_sys.sql</pre>
Строка 32: Строка 32:
или
или


<pre>sudo -u postgres psql -d testdb -f /usr/share/postgresql/9.1/contrib/postgis-2.0/postgis.sql</pre>
<pre>sudo -u postgres psql -d testdb -f /usr/share/postgresql/9.1/contrib/postgis-2.0/postgis.sql
sudo -u postgres psql -d testdb -f /usr/share/postgresql/9.1/contrib/postgis-2.0/spatial_ref_sys.sql</pre>


===Загрузка данных===
===Загрузка данных===

Версия от 11:11, 13 апреля 2013

Эта страница является черновиком статьи.


Еще заготовка шпаргалки

Установка

sudo apt-get install postgis

В Ubuntu 12.04 по-умолчанию все ставится в /usr/share/postgresql/9.1/contrib/postgis-2.0

Создание базы

В шелл (база создатся на пользователя pgsql):

createdb -U postgres testdb

или

sudo -u postgres createdb testdb

Начало работы

Создание пользователя

CREATE USER admin PASSWORD 'admin';

Назначение его администратором:

ALTER DATABASE testdb OWNER TO admin;

Добавление функций PostGIS и систем координат (нужно знать, куда установился postgis):

psql -U pgsql -d testdb -f /usr/local/share/postgis/postgis.sql
psql -U pgsql -d testdb -f /usr/local/share/postgis/spatial_ref_sys.sql

или

sudo -u postgres psql -d testdb -f /usr/share/postgresql/9.1/contrib/postgis-2.0/postgis.sql
sudo -u postgres psql -d testdb -f /usr/share/postgresql/9.1/contrib/postgis-2.0/spatial_ref_sys.sql

Загрузка данных

shp2pgsql

Загрузка данных в базу проводится в 2 этапа, сначала слой выгружается в sql, а затем он грузится в базу

shp2pgsql -i -D -s 4326 -W cp1251 topo250m-rus.shp > topo250-rus.sql
psql -U pgsql -f topo250-rus.sql -d testdb 

ogr2ogr


Права

Разрешение подключаться к определенной таблице базы пользователю с определенным именем (пользователь уже заведен в базе):

psql -U pgsql -d gen -c 'GRANT SELECT ON TABLE "topo250m-rus" TO guest;'

Удаление базы

Аналогично созданию, только dropdb, вместо createdb

dropdb -U postgres testdb