PostGIS のインストール

PostGIS は、PostgreSQL に地理オブジェクトのサポートを追加し、それを空間データベースに変えます。PostGIS をビルドする前に、 GEOSPROJGDAL をインストールする必要があります。追加のライブラリが必要な場合もあるので、 PostGIS requirements を参照してください。

GeoDjango を PostGIS で使う場合、データベースアダプタとして psycopg または psycopg2 モジュールが必要です。

Debian/Ubuntuでは、次のパッケージをインストールすることが推奨されます: postgresql-x, postgresql-x-postgis-3, postgresql-server-dev-x, python3-psycopg3 (xはインストールしたいPostgreSQLのバージョンに対応します)。別の方法として、 build from source ことも可能です。 macOSWindows の場合は、プラットフォーム固有の手順を参照してください。

インストール後

空間データベースを作成する

PostGIS には、空間機能を有効にするために使用される PostgreSQL 用の拡張機能が含まれています。

$ createdb  <db name>
$ psql <db name>
> CREATE EXTENSION postgis;

データベースユーザーは、CREATE EXTENSION postgis; を実行するためにはスーパーユーザーである必要があります。このコマンドは、 migrate プロセス中に実行されます。プロジェクトでの代替方法として、マイグレーションオペレーションを使用する方法があります:

from django.contrib.postgres.operations import CreateExtension
from django.db import migrations


class Migration(migrations.Migration):
    operations = [CreateExtension("postgis"), ...]

PostGIS のラスタ機能を使用する予定がある場合は、postgis_raster 拡張機能も有効にする必要があります。拡張機能は、CreateExtension マイグレーション操作を使用してインストールするか、または直接 CREATE EXTENSION postgis_raster; を実行することでインストールできます。

GeoDjango は今のところ PostGIS topology functionality を利用していません。これらの機能をいつか使いたければ、 CREATE EXTENSION postgis_topology; を実行して postgis_topology 拡張機能をインストールすることもできます。

データベースの管理

データベースの管理には、pgAdmin III プログラム (Start ‣ PostgreSQL X ‣ pgAdmin III) または SQL Shell (Start ‣ PostgreSQL X ‣ SQL Shell) を使用できます。例えば、 geodjango 空間データベースとユーザを作成するには、postgres ユーザとして SQL Shell から次のコマンドを実行します:

postgres# CREATE USER geodjango PASSWORD 'my_passwd';
postgres# CREATE DATABASE geodjango OWNER geodjango;
Back to Top