0

尝试使用 h2-1.4.197.jar 使用通用命令行连接到 H2 数据库,此 H2 文件数据库来自 Geonetwork 3.2 实例。

使用以下字符串: java -cp h2*.jar org.h2.tools.Shell -user "admin" -password "gnos" -url "jdbc:h2:~/git/geonetwork/geonetwork" -driver org.h2.Driver -sql "SELECT 1"

我得到以下异常: Exception in thread "main" org.h2.jdbc.JdbcSQLException: Unique index or primary key violation: "PRIMARY KEY ON """".PAGE_INDEX"; SQL statement: ALTER TABLE PUBLIC.CATEGORIESDES ADD CONSTRAINT PUBLIC.FK_69P88C8991LETUOQ16JDDI307 FOREIGN KEY(IDDES) REFERENCES PUBLIC.CATEGORIES(ID) NOCHECK [23505-197]

问题:为什么会发生这种违规行为以及如何解决?

4

1 回答 1

0

使用来自 Geonetwork (h2-1.3.174.jar) 的 h2 jar 允许访问数据库:

java -cp h2-1.3.174.jar org.h2.tools.Shell -user "admin" -password "gnos" -url "jdbc:h2:~/git/geonetwork/geonetwork" -driver org.h2.Driver -sql "SELECT 1" 1 1 (1 row, 4 ms)

问题是由不正确的 h2 版本引起的

于 2018-09-04T14:43:12.233 回答