安装 SpatiaLite

SpatiaLite 为 SQLite 添加了空间支持,将其变成了一个功能齐全的空间数据库。

首先,检查是否可以从系统包或二进制文件中安装 SpatiaLite。

例如,在打包了 SpatiaLite 4.3+ 的基于 Debian 的发行版上,尝试安装 libsqlite3-mod-spatialite 包。对于较旧的版本,安装 spatialite-bin

对于 macOS,请遵循下面的说明

对于 Windows,您可以在Gaia-SINS 主页上找到二进制文件。

无论如何,您应该始终能够从源代码安装

从源代码安装

在构建 SpatiaLite 之前,应安装GEOS 和 PROJ

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 用户可以使用Homebrew

Homebrew

Homebrew 代表您处理所有与 SpatiaLite 相关的包,包括 SQLite、SpatiaLite、PROJ 和 GEOS。像这样安装它们

$ brew update
$ brew install spatialite-tools
$ brew install gdal

最后,为了使 GeoDjango 能够找到 SpatiaLite 库,请将 SPATIALITE_LIBRARY_PATH 设置设置为其路径。这将位于您的 brew 安装路径中,您可以使用以下命令检查:

$ brew --prefix
/opt/homebrew

使用此 brew 安装路径,可以像这样构造完整路径:

SPATIALITE_LIBRARY_PATH = "/opt/homebrew/lib/mod_spatialite.dylib"
返回顶部