2012-10-19 18:19:17 +02:00
|
|
|
=====================
|
2016-08-09 18:46:14 +02:00
|
|
|
Installing SpatiaLite
|
2012-10-19 18:19:17 +02:00
|
|
|
=====================
|
|
|
|
|
|
|
|
`SpatiaLite`__ adds spatial support to SQLite, turning it into a full-featured
|
|
|
|
spatial database.
|
|
|
|
|
2016-08-09 18:46:14 +02:00
|
|
|
First, check if you can install SpatiaLite from system packages or binaries.
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2021-04-06 12:44:40 +02:00
|
|
|
For example, on Debian-based distributions that package SpatiaLite 4.3+, try to
|
2019-04-17 07:24:04 +02:00
|
|
|
install the ``libsqlite3-mod-spatialite`` package. For older releases install
|
|
|
|
``spatialite-bin``.
|
2016-01-28 09:16:46 -05:00
|
|
|
|
2017-04-23 22:06:12 +02:00
|
|
|
For macOS, follow the :ref:`instructions below<spatialite_macos>`.
|
2016-01-28 09:16:46 -05:00
|
|
|
|
|
|
|
For Windows, you may find binaries on the `Gaia-SINS`__ home page.
|
|
|
|
|
|
|
|
In any case, you should always be able to :ref:`install from source
|
|
|
|
<spatialite_source>`.
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2021-04-27 12:09:00 +01:00
|
|
|
__ https://www.gaia-gis.it/fossil/libspatialite/index
|
2017-03-16 14:01:45 -04:00
|
|
|
__ https://www.gaia-gis.it/gaia-sins/
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2018-01-31 11:14:41 -05:00
|
|
|
.. _spatialite_source:
|
|
|
|
|
2012-10-19 18:19:17 +02:00
|
|
|
Installing from source
|
2016-01-03 12:56:22 +02:00
|
|
|
======================
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2020-05-10 22:30:03 +02:00
|
|
|
:doc:`GEOS and PROJ</ref/contrib/gis/install/geolibs>` should be installed
|
2014-11-26 12:46:06 -05:00
|
|
|
prior to building SpatiaLite.
|
2012-10-19 18:19:17 +02:00
|
|
|
|
|
|
|
SQLite
|
2016-01-03 12:56:22 +02:00
|
|
|
------
|
2012-10-19 18:19:17 +02:00
|
|
|
|
|
|
|
Check first if SQLite is compiled with the `R*Tree module`__. Run the sqlite3
|
2023-02-09 16:48:46 +01:00
|
|
|
command line interface and enter the following query:
|
|
|
|
|
|
|
|
.. code-block:: sqlite3
|
2012-10-19 18:19:17 +02:00
|
|
|
|
|
|
|
sqlite> CREATE VIRTUAL TABLE testrtree USING rtree(id,minX,maxX,minY,maxY);
|
|
|
|
|
|
|
|
If you obtain an error, you will have to recompile SQLite from source. Otherwise,
|
2019-06-17 16:54:55 +02:00
|
|
|
skip this section.
|
2012-10-19 18:19:17 +02:00
|
|
|
|
|
|
|
To install from sources, download the latest amalgamation source archive from
|
2023-02-09 16:48:46 +01:00
|
|
|
the `SQLite download page`__, and extract:
|
|
|
|
|
|
|
|
.. code-block:: shell
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2018-06-12 22:22:05 +03:00
|
|
|
$ wget https://www.sqlite.org/YYYY/sqlite-amalgamation-XXX0000.zip
|
|
|
|
$ unzip sqlite-amalgamation-XXX0000.zip
|
|
|
|
$ cd sqlite-amalgamation-XXX0000
|
2012-10-19 18:19:17 +02:00
|
|
|
|
|
|
|
Next, run the ``configure`` script -- however the ``CFLAGS`` environment variable
|
2023-02-09 16:48:46 +01:00
|
|
|
needs to be customized so that SQLite knows to build the R*Tree module:
|
|
|
|
|
|
|
|
.. code-block:: shell
|
2012-10-19 18:19:17 +02:00
|
|
|
|
|
|
|
$ CFLAGS="-DSQLITE_ENABLE_RTREE=1" ./configure
|
|
|
|
$ make
|
|
|
|
$ sudo make install
|
|
|
|
$ cd ..
|
|
|
|
|
2015-11-29 08:29:46 -08:00
|
|
|
__ https://www.sqlite.org/rtree.html
|
|
|
|
__ https://www.sqlite.org/download.html
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2013-09-12 19:34:22 -03:00
|
|
|
.. _spatialitebuild:
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2015-10-31 00:04:20 +05:00
|
|
|
SpatiaLite library (``libspatialite``)
|
2016-01-03 12:56:22 +02:00
|
|
|
--------------------------------------
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2015-10-31 00:04:20 +05:00
|
|
|
Get the latest SpatiaLite library source bundle from the
|
2023-02-09 16:48:46 +01:00
|
|
|
`download page`__:
|
|
|
|
|
|
|
|
.. code-block:: shell
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2018-06-12 22:22:05 +03:00
|
|
|
$ wget https://www.gaia-gis.it/gaia-sins/libspatialite-sources/libspatialite-X.Y.Z.tar.gz
|
|
|
|
$ tar xaf libspatialite-X.Y.Z.tar.gz
|
|
|
|
$ cd libspatialite-X.Y.Z
|
2015-10-31 00:04:20 +05:00
|
|
|
$ ./configure
|
2012-10-19 18:19:17 +02:00
|
|
|
$ make
|
|
|
|
$ sudo make install
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
2017-04-23 22:06:12 +02:00
|
|
|
For macOS users building from source, the SpatiaLite library *and* tools
|
2023-02-09 16:48:46 +01:00
|
|
|
need to have their ``target`` configured:
|
|
|
|
|
|
|
|
.. code-block:: shell
|
2012-10-19 18:19:17 +02:00
|
|
|
|
|
|
|
$ ./configure --target=macosx
|
|
|
|
|
2018-09-25 23:48:47 -07:00
|
|
|
__ https://www.gaia-gis.it/gaia-sins/libspatialite-sources/
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2017-04-23 22:06:12 +02:00
|
|
|
.. _spatialite_macos:
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2017-04-23 22:06:12 +02:00
|
|
|
macOS-specific instructions
|
2016-01-03 12:56:22 +02:00
|
|
|
==============================
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2022-12-14 11:18:18 +01:00
|
|
|
To install the SpatiaLite library and tools, macOS users can use `Homebrew`_.
|
2012-10-19 18:19:17 +02:00
|
|
|
|
2014-11-25 19:48:36 -08:00
|
|
|
Homebrew
|
2016-01-03 12:56:22 +02:00
|
|
|
--------
|
2014-11-25 19:48:36 -08:00
|
|
|
|
|
|
|
`Homebrew`_ handles all the SpatiaLite related packages on your behalf,
|
2023-02-09 16:48:46 +01:00
|
|
|
including SQLite, SpatiaLite, PROJ, and GEOS. Install them like this:
|
|
|
|
|
|
|
|
.. code-block:: shell
|
2014-11-25 19:48:36 -08:00
|
|
|
|
|
|
|
$ brew update
|
|
|
|
$ brew install spatialite-tools
|
|
|
|
$ brew install gdal
|
|
|
|
|
2024-04-10 22:15:42 +01:00
|
|
|
Finally, for GeoDjango to be able to find the SpatiaLite library, set
|
|
|
|
the ``SPATIALITE_LIBRARY_PATH`` setting to its path. This will be within
|
|
|
|
your brew install path, which you can check with:
|
2014-11-25 19:48:36 -08:00
|
|
|
|
2024-04-10 22:15:42 +01:00
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
$ brew --prefix
|
|
|
|
/opt/homebrew
|
|
|
|
|
|
|
|
Using this brew install path, the full path can be constructed like this::
|
|
|
|
|
|
|
|
SPATIALITE_LIBRARY_PATH = "/opt/homebrew/lib/mod_spatialite.dylib"
|
2014-11-25 19:48:36 -08:00
|
|
|
|
2017-05-20 17:51:21 +02:00
|
|
|
.. _Homebrew: https://brew.sh/
|