如何解决在MacOS上将Spacelite与xerial / sqlite-jdbc一起使用
在加载Java中的spacespaceite扩展以读取GeoPackage时遇到一些问题,我有以下代码段:
import org.sqlite.sqliteConfig;
import java.net.URI;
import java.net.URISyntaxException;
import java.sql.Connection;
import java.sql.sqlException;
import java.sql.Statement;
public class DatabaseTest {
public static void main(String[] args) throws sqlException,URISyntaxException {
URI databaseURI = DatabaseTest.class.getResource("/database.gpkg").toURI();
String databaseURL = String.format("jdbc:sqlite:%s",databaseURI);
sqliteConfig config = new sqliteConfig();
config.enableLoadExtension(true);
Connection connection = config.createConnection(databaseURL);
Statement statement = connection.createStatement();
boolean success = statement.execute("SELECT load_extension('mod_spatialite')");
System.out.println(success);
statement.close();
connection.close();
}
}
这将导致[sqlITE_ERROR] sql error or missing database (dlopen(mod_spatialite.dylib,10): image not found)
如果我更改为
boolean success = statement.execute("SELECT load_extension('/usr/local/lib/mod_spatialite')");
结果为Process finished with exit code 134 (interrupted by signal 6: SIGABRT)
有什么我想念的吗?我已经使用Homebrew安装了sqlite3
和spatialite
,而这就是我要使用的spatialite
的版本。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。