Added, documented support for SpatiaLite 3.0 to GeoDjango.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@17496 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
4768f39c95
commit
c406b554c7
|
@ -102,21 +102,30 @@ class SpatiaLiteCreation(DatabaseCreation):
|
||||||
"""
|
"""
|
||||||
This routine loads up the SpatiaLite SQL file.
|
This routine loads up the SpatiaLite SQL file.
|
||||||
"""
|
"""
|
||||||
# Getting the location of the SpatiaLite SQL file, and confirming
|
if self.connection.ops.spatial_version[:2] >= (3, 0):
|
||||||
# it exists.
|
# Spatialite >= 3.0.x -- No ned to load any SQL file, calling
|
||||||
spatialite_sql = self.spatialite_init_file()
|
# InitSpatialMetaData() transparently creates the spatial metadata
|
||||||
if not os.path.isfile(spatialite_sql):
|
# tables
|
||||||
raise ImproperlyConfigured('Could not find the required SpatiaLite initialization '
|
|
||||||
'SQL file (necessary for testing): %s' % spatialite_sql)
|
|
||||||
|
|
||||||
# Opening up the SpatiaLite SQL initialization file and executing
|
|
||||||
# as a script.
|
|
||||||
sql_fh = open(spatialite_sql, 'r')
|
|
||||||
try:
|
|
||||||
cur = self.connection._cursor()
|
cur = self.connection._cursor()
|
||||||
cur.executescript(sql_fh.read())
|
cur.execute("SELECT InitSpatialMetaData()")
|
||||||
finally:
|
else:
|
||||||
sql_fh.close()
|
# Spatialite < 3.0.x -- Load the initial SQL
|
||||||
|
|
||||||
|
# Getting the location of the SpatiaLite SQL file, and confirming
|
||||||
|
# it exists.
|
||||||
|
spatialite_sql = self.spatialite_init_file()
|
||||||
|
if not os.path.isfile(spatialite_sql):
|
||||||
|
raise ImproperlyConfigured('Could not find the required SpatiaLite initialization '
|
||||||
|
'SQL file (necessary for testing): %s' % spatialite_sql)
|
||||||
|
|
||||||
|
# Opening up the SpatiaLite SQL initialization file and executing
|
||||||
|
# as a script.
|
||||||
|
sql_fh = open(spatialite_sql, 'r')
|
||||||
|
try:
|
||||||
|
cur = self.connection._cursor()
|
||||||
|
cur.executescript(sql_fh.read())
|
||||||
|
finally:
|
||||||
|
sql_fh.close()
|
||||||
|
|
||||||
def spatialite_init_file(self):
|
def spatialite_init_file(self):
|
||||||
# SPATIALITE_SQL may be placed in settings to tell GeoDjango
|
# SPATIALITE_SQL may be placed in settings to tell GeoDjango
|
||||||
|
|
|
@ -80,7 +80,7 @@ Program Description Required
|
||||||
:ref:`GDAL <ref-gdal>` Geospatial Data Abstraction Library No (but, required for SQLite) 1.8, 1.7, 1.6, 1.5, 1.4
|
:ref:`GDAL <ref-gdal>` Geospatial Data Abstraction Library No (but, required for SQLite) 1.8, 1.7, 1.6, 1.5, 1.4
|
||||||
:ref:`GeoIP <ref-geoip>` IP-based geolocation library No 1.4
|
:ref:`GeoIP <ref-geoip>` IP-based geolocation library No 1.4
|
||||||
`PostGIS`__ Spatial extensions for PostgreSQL Yes (PostgreSQL only) 1.5, 1.4, 1.3
|
`PostGIS`__ Spatial extensions for PostgreSQL Yes (PostgreSQL only) 1.5, 1.4, 1.3
|
||||||
`SpatiaLite`__ Spatial extensions for SQLite Yes (SQLite only) 2.4, 2.3
|
`SpatiaLite`__ Spatial extensions for SQLite Yes (SQLite only) 3.0, 2.4, 2.3
|
||||||
======================== ==================================== ================================ ==========================
|
======================== ==================================== ================================ ==========================
|
||||||
|
|
||||||
.. admonition:: Install GDAL
|
.. admonition:: Install GDAL
|
||||||
|
@ -560,15 +560,42 @@ Creating a Spatial Database for SpatiaLite
|
||||||
-------------------------------------------
|
-------------------------------------------
|
||||||
|
|
||||||
After the SpatiaLite library and tools have been installed, it is now possible
|
After the SpatiaLite library and tools have been installed, it is now possible
|
||||||
to create spatial database for use with GeoDjango. In order to do this, download
|
to create a spatial database for use with GeoDjango.
|
||||||
the spatial database initialization SQL from the `SpatiaLite Resources`__ page::
|
|
||||||
|
For this, a number of spatial metadata tables must be created in the database
|
||||||
|
before any spatial query is performed against it.
|
||||||
|
|
||||||
|
If you are using SpatiaLite 3.0 or newer then use the ``spatialite`` utility to
|
||||||
|
call the ``InitSpatiaMetaData()`` function whch will take care of that (you can
|
||||||
|
safely ignore the error messages shown) then you can skip the rest of this
|
||||||
|
section::
|
||||||
|
|
||||||
|
$ spatialite geodjango.db "SELECT InitSpatialMetaData();"
|
||||||
|
the SPATIAL_REF_SYS table already contains some row(s)
|
||||||
|
InitSpatiaMetaData ()error:"table spatial_ref_sys already exists"
|
||||||
|
0
|
||||||
|
|
||||||
|
If you re using a version of Spatialite older than 3.0 then to achieve the same
|
||||||
|
result you need to download a database initialization file and execute the SQL
|
||||||
|
queries it contains against your database.
|
||||||
|
|
||||||
|
First, get it from the appropiate SpatiaLite Resources page (i.e.
|
||||||
|
http://www.gaia-gis.it/spatialite-2.3.1/resources.html for 2.3 or
|
||||||
|
http://www.gaia-gis.it/spatialite-2.4.0/ for 2.4)::
|
||||||
|
|
||||||
$ wget http://www.gaia-gis.it/spatialite-2.3.1/init_spatialite-2.3.sql.gz
|
$ wget http://www.gaia-gis.it/spatialite-2.3.1/init_spatialite-2.3.sql.gz
|
||||||
$ gunzip init_spatialite-2.3.sql.gz
|
$ gunzip init_spatialite-2.3.sql.gz
|
||||||
|
|
||||||
|
(Or, if you are using SpatiaLite 2.4 then do::
|
||||||
|
|
||||||
|
$ wget http://www.gaia-gis.it/spatialite-2.4.0/init_spatialite-2.4.sql.gz
|
||||||
|
$ gunzip init_spatialite-2.4.sql.gz
|
||||||
|
|
||||||
|
)
|
||||||
|
|
||||||
Now, the ``spatialite`` command can be used to initialize a spatial database::
|
Now, the ``spatialite`` command can be used to initialize a spatial database::
|
||||||
|
|
||||||
$ spatialite geodjango.db < init_spatialite-2.3.sql
|
$ spatialite geodjango.db < init_spatialite-2.X.sql
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
|
@ -576,10 +603,6 @@ Now, the ``spatialite`` command can be used to initialize a spatial database::
|
||||||
you want to use. Use the same in the :setting:`DATABASES` ``"name"`` key
|
you want to use. Use the same in the :setting:`DATABASES` ``"name"`` key
|
||||||
inside your ``settings.py``.
|
inside your ``settings.py``.
|
||||||
|
|
||||||
|
|
||||||
__ http://www.gaia-gis.it/spatialite-2.3.1/resources.html
|
|
||||||
|
|
||||||
|
|
||||||
Add ``django.contrib.gis`` to :setting:`INSTALLED_APPS`
|
Add ``django.contrib.gis`` to :setting:`INSTALLED_APPS`
|
||||||
-------------------------------------------------------
|
-------------------------------------------------------
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue