安装 SpatiaLite — Django 文档
安装 SpatiaLite
SpatiaLite 为 SQLite 增加了空间支持,使其成为功能齐全的空间数据库。
首先,检查您是否可以从系统包或二进制文件安装 SpatiaLite。
例如,在打包 SpatiaLite 4.2+ 的基于 Debian 的发行版上,尝试安装 libsqlite3-mod-spatialite
包。 对于旧版本,请安装 spatialite-bin
。
对于 macOS,请按照下面的 说明进行操作 。
对于 Windows,您可以在 Gaia-SINS 主页上找到二进制文件。
在任何情况下,您都应该始终能够从源 进行 安装。
从源安装
GEOS 和 PROJ.4 应该在构建 SpatiaLite 之前安装。
SQLite
首先检查 SQLite 是否使用 R*Tree 模块 编译。 运行 sqlite3 命令行界面并输入以下查询:
sqlite> CREATE VIRTUAL TABLE testrtree USING rtree(id,minX,maxX,minY,maxY);
如果出现错误,则必须从源代码重新编译 SQLite。 否则,请跳过本节。
要从源代码安装,请从 SQLite 下载页面 下载最新的合并源文件,然后解压缩:
$ wget https://www.sqlite.org/YYYY/sqlite-amalgamation-XXX0000.zip
$ unzip sqlite-amalgamation-XXX0000.zip
$ cd sqlite-amalgamation-XXX0000
接下来,运行 configure
脚本——但是需要自定义 CFLAGS
环境变量,以便 SQLite 知道构建 R*Tree 模块:
$ CFLAGS="-DSQLITE_ENABLE_RTREE=1" ./configure
$ make
$ sudo make install
$ cd ..
SpatiaLite 库 (libspatialite)
从 下载页面 获取最新的 SpatiaLite 库源包:
$ 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
$ ./configure
$ make
$ sudo make install
笔记
对于从源代码构建的 macOS 用户,SpatiaLite 库 和 工具需要配置其 target
:
$ ./configure --target=macosx
macOS 特定的说明
要安装 SpatiaLite 库和工具,macOS 用户可以在 KyngChaos 包 和 Homebrew 之间进行选择。
京混沌
首先,按照 KyngChaos 包 部分中的说明进行操作。
创建 SpatiaLite 数据库时,需要 spatialite
程序。 但是,不要尝试从源代码编译 SpatiaLite 工具,而是下载适用于 macOS 的 SpatiaLite Tools 包,然后将 spatialite
安装在 PATH
中可用的位置。 例如:
$ curl -O https://www.kyngchaos.com/files/software/frameworks/Spatialite_Tools-4.3.zip
$ unzip Spatialite_Tools-4.3.zip
$ cd Spatialite\ Tools/tools
$ sudo cp spatialite /Library/Frameworks/SQLite3.framework/Programs
最后,为了让 GeoDjango 能够找到 KyngChaos SpatiaLite 库,请将以下内容添加到您的 settings.py
:
SPATIALITE_LIBRARY_PATH='/Library/Frameworks/SQLite3.framework/SQLite3'
家酿
Homebrew 代表您处理所有与 SpatiaLite 相关的包,包括 SQLite、SpatiaLite、PROJ 和 GEOS。 像这样安装它们:
$ brew update
$ brew install spatialite-tools
$ brew install gdal
最后,为了让 GeoDjango 能够找到 SpatiaLite 库,请将以下内容添加到您的 settings.py
:
SPATIALITE_LIBRARY_PATH='/usr/local/lib/mod_spatialite.dylib'