【问题标题】:Importing OpenStreetMap data into PostgreSQL database将 OpenStreetMap 数据导入 PostgreSQL 数据库
【发布时间】:2012-10-20 06:23:20
【问题描述】:

我正在尝试使用 call osmosis.bat --read-xml file="map.osm" --write-pgsimp user="ccp-web-user" database="ccp-web2" password="ccp-web-password" 之类的调用将以下 OpenStreetMap 地图之一 123 导入 PostgreSQL 数据库,但我总是遵循错误消息。

SCHWERWIEGEND: Thread for task 1-read-xml failed
org.openstreetmap.osmosis.core.OsmosisRuntimeException: Unable to read the schema version from the schema info table.
        at org.openstreetmap.osmosis.pgsimple.common.SchemaVersionValidator.validateDBVersion(SchemaVersionValidator.java:90)
        at org.openstreetmap.osmosis.pgsimple.common.SchemaVersionValidator.validateVersion(SchemaVersionValidator.java:50)
        at org.openstreetmap.osmosis.pgsimple.v0_6.PostgreSqlWriter.initialize(PostgreSqlWriter.java:183)
        at org.openstreetmap.osmosis.pgsimple.v0_6.PostgreSqlWriter.process(PostgreSqlWriter.java:773)
        at org.openstreetmap.osmosis.xml.v0_6.impl.BoundsElementProcessor.end(BoundsElementProcessor.java:84)
        at org.openstreetmap.osmosis.xml.v0_6.impl.OsmHandler.endElement(OsmHandler.java:107)
        at org.apache.xerces.parsers.AbstractSAXParser.endElement(Unknown Source)
        at org.apache.xerces.parsers.AbstractXMLDocumentParser.emptyElement(Unknown Source)
        at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanStartElement(Unknown Source)
        at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(Unknown Source)
        at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown Source)
        at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)
        at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)
        at org.apache.xerces.parsers.XMLParser.parse(Unknown Source)
        at org.apache.xerces.parsers.AbstractSAXParser.parse(Unknown Source)
        at org.apache.xerces.jaxp.SAXParserImpl$JAXPSAXParser.parse(Unknown Source)
        at org.apache.xerces.jaxp.SAXParserImpl.parse(Unknown Source)
        at javax.xml.parsers.SAXParser.parse(Unknown Source)
        at org.openstreetmap.osmosis.xml.v0_6.XmlReader.run(XmlReader.java:111)
        at java.lang.Thread.run(Unknown Source)
Caused by: org.postgresql.util.PSQLException: FEHLER: Relation ╗schema_info½ existiert nicht Position: 21
        at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2102)
        at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:1835)
        at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:257)
        at org.postgresql.jdbc2.AbstractJdbc2Statement.execute(AbstractJdbc2Statement.java:500)
        at org.postgresql.jdbc2.AbstractJdbc2Statement.executeWithFlags(AbstractJdbc2Statement.java:374)
        at org.postgresql.jdbc2.AbstractJdbc2Statement.executeQuery(AbstractJdbc2Statement.java:254)
        at org.openstreetmap.osmosis.pgsimple.common.SchemaVersionValidator.validateDBVersion(SchemaVersionValidator.java:71)
        ... 19 more
30.10.2012 23:06:56 org.openstreetmap.osmosis.core.Osmosis main
SCHWERWIEGEND: Execution aborted.
org.openstreetmap.osmosis.core.OsmosisRuntimeException: One or more tasks failed
.
        at org.openstreetmap.osmosis.core.pipeline.common.Pipeline.waitForCompletion(Pipeline.java:146)
        at org.openstreetmap.osmosis.core.Osmosis.run(Osmosis.java:92)
        at org.openstreetmap.osmosis.core.Osmosis.main(Osmosis.java:37)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
        at java.lang.reflect.Method.invoke(Unknown Source)
        at org.codehaus.plexus.classworlds.launcher.Launcher.launchStandard(Launcher.java:329)
        at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:239)
        at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:409)
        at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:352)
        at org.codehaus.classworlds.Launcher.main(Launcher.java:47)

我该如何解决这个问题?

【问题讨论】:

  • 在堆栈跟踪中有一条消息Table schema_info doesn't exist。我正在寻找如何解决它...

标签: postgresql postgis openstreetmap postgresql-9.2


【解决方案1】:

您需要按照here 的描述初始化 PostGIS 简单架构。

架构创建脚本可以在 osmosis 发行版的脚本目录中找到。

这些脚本是:

  • pgsimple_schema_0.6.sql - 构建最小架构。
  • pgsimple_schema_0.6_action.sql - 添加可选的“action”表,允许派生表在应用差异时保持最新。
  • pgsimple_schema_0.6_bbox.sql - 将可选的 bbox 列添加到路表中。
  • pgsimple_schema_0.6_linestring.sql - 将可选的线串列添加到路表中。
  • pgsimple_load_0.6.sql - 适用于加载由 --write-pgsimp-dump 任务创建的 COPY 文件的示例数据加载脚本。

如果您使用 PgAdmin3,请打开这些文件并执行它们。或者使用psql 命令。当然 PostGIS 应该安装在您的数据库中。

【讨论】:

  • 我在PostgreSQL\9.2\share\contrib\postgis-2.0 目录中找不到这些文件。这是否意味着 Osmosis 失败是因为它需要另一个 PostGIS 版本?
  • pgsimple_* 文件位于osmosis\scripts 目录中。据我所知,渗透与 PostGIS 2.0 配合得很好。
  • 在 PgAdmin3 中加载 pgsimple_load_0.6.sql 时,我收到错误 [ERROR ] 18.0: syntax error, unexpected character
  • 我尝试再次运行命令call osmosis.bat --read-xml file="map.osm" --write-pgsimp user="ccp-web-user" database="ccp-gis-test" password="ccp-web-password" validateSchemaVersion="no"。现在我得到一个不同的错误:SCHWERWIEGEND: Thread for task 1-read-xml failed org.openstreetmap.osmosis.core.OsmosisRuntimeException: Unable to execute statement. at org.openstreetmap.osmosis.pgsimple.common.DatabaseContext.executeStatement(DatabaseContext.java:159) at org.openstreetmap.osmosis.pgsimple.v0_6.impl.IndexManager.prepareForLoad(IndexManager.java:106)
  • PgAdmin3 有一种特殊的方言叫做pgScript。看来您正在使用它 (Query|Execute pgScript) 而不是普通的 SQL (Query|Execute)。在干净的 PostGIS 数据库上尝试 Query|Execute
【解决方案2】:
osmosis.bat --read-xml file="map.osm" --write-pgsimp validateSchemaVersion=no user="ccp-web-user" database="ccp-web2" password="ccp-web-password"

【讨论】:

  • 为您的代码添加解释并将代码格式化为代码
【解决方案3】:

我刚遇到这个问题,并在 Ubuntu 上为自己找到了解决方案。

如果你认为你已经通过 psql 命令执行了https://wiki.openstreetmap.org/wiki/Osmosis/PostGIS_Setup 的步骤,但仍然遇到错误,那么在 Linux 终端上执行 psql 命令时可能存在用户权限问题,例如创建时postgis 和 hstore 扩展,以及在执行 pgsnapshot 架构时。

我做了什么: - 在终端上创建数据库后 - 我使用了 PgAdmin,进入数据库(例如 pgsnapshot)并执行创建扩展 postgis 和 hstore 的步骤。然后在该 PgAdmin 查询工具中执行模式创建脚本之一(例如 pgsnapshot_schema_0.6.sql)。 - 之后,返回终端执行命令(例如:osmosis --read-pbf ....)

这些步骤解决了我的问题。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2016-10-16
    • 1970-01-01
    • 2019-10-05
    • 2011-07-22
    • 2016-11-29
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多