【问题标题】:How to start launch the HSQLDB server as described in the Hibernate tutorial?如何按照 Hibernate 教程中的说明启动 HSQLDB 服务器?
【发布时间】:2012-12-05 01:12:13
【问题描述】:

尝试执行this Hibernate tutorial 中的第 4 步:

mvn exec:java -Dexec.mainClass="org.hsqldb.Server" -Dexec.args="-database.0 file:target/data/tutorial"

我收到此错误:

[INFO] Scanning for projects...
[INFO] Searching repository for plugin with prefix: 'exec'.
[INFO] ------------------------------------------------------------------------
[INFO] Building First Hibernate Tutorial
[INFO]    task-segment: [exec:java]
[INFO] ------------------------------------------------------------------------
[INFO] Preparing exec:java
[INFO] No goals needed for project - skipping
[INFO] [exec:java {execution: default-cli}]
[WARNING]
java.lang.ClassNotFoundException: org.hsqldb.Server
        at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
        at org.codehaus.mojo.exec.ExecJavaMojo$1.run(ExecJavaMojo.java:285)
        at java.lang.Thread.run(Thread.java:662)
[INFO] ------------------------------------------------------------------------
[ERROR] BUILD ERROR
[INFO] ------------------------------------------------------------------------
[INFO] An exception occured while executing the Java class. org.hsqldb.Server

[INFO] ------------------------------------------------------------------------
[INFO] For more information, run Maven with the -e switch
[INFO] ------------------------------------------------------------------------
[INFO] Total time: < 1 second
[INFO] Finished at: Mon Dec 17 16:35:42 EST 2012
[INFO] Final Memory: 6M/15M
[INFO] ------------------------------------------------------------------------

尽管下载了最新的 hsqldb 包并按照the FAQ 安装它,但还是会出现这种情况。 hsqldb.jar 文件位于 C:\hsqldb-2.2.9\hsqldb-2.2.9\hsqldb\lib 中,类路径 env var 指向它:

CLASSPATH=C:\hsqldb-2.2.9\hsqldb-2.2.9\hsqldb\lib

那么为什么我会收到这个 ClassNotFoundException: org.hsqldb.Server 错误?

我做错了什么?

【问题讨论】:

    标签: java hibernate maven hsqldb


    【解决方案1】:

    首先,您的 CLASSPATH 通常不适用于任何 jar。必须指定 jar 名称,例如:

    CLASSPATH=C:\hsqldb-2.2.9\hsqldb-2.2.9\hsqldb\lib\hsqldb.jar
    

    其次,本教程不需要 CLASSPATH,因为它是一个 Maven 项目。您应该将相关依赖项添加到您提到的教程的第 1.1.1 节中描述的 pom.xml 文件中。只需将此块添加到选项卡内 pom.xml 中列出的块中:

    <dependency>
        <groupId>org.hsqldb</groupId>
        <artifactId>hsqldb</artifactId>
        <version>2.2.9</version>
    </dependency>
    

    【讨论】:

    • 另外,我刚刚验证了如果&lt;dependency&gt; 存在于pom.xml 中,则环境中不需要CLASSPATH。有趣的是 Maven 是如何做到这一点的。
    【解决方案2】:

    根据http://docs.oracle.com/javase/7/docs/technotes/tools/windows/classpath.html,需要指定以.jar结尾的整个路径。如果有多个 jar 文件,可以尝试指定 C:\path\to\hibernate*.jar

    如果只指定目录,则只加载 *.class 文件。

    其他可能性是您设置的 CLASSPATH 变量仅对 shell 会话有效,而不是全局 - 因此 maven 命令没有读取它。尝试通过 Windows 系统设置进行设置。

    【讨论】:

      【解决方案3】:

      我建议从http://sourceforge.net/projects/hibernate/files/hibernate3/3.3.2.GA/ 下载新的教程副本并尝试构建它。如果您缺少 hsqldb 或 commons-logging 等依赖项,我通过添加 maven 项目存储库 - https://repository.jboss.org/nexus/content/repositories/thirdparty-releases 解决了这个问题。下载完所有工件后,我就可以运行 HSQLDB 服务器了。建议将您当前的项目与新下载的项目进行比较。它应该可以解决您的问题。

      【讨论】:

      • 感谢您和@gerrytan +1。
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2013-11-25
      • 2014-10-11
      • 2017-02-28
      • 1970-01-01
      • 2012-07-11
      • 2016-06-15
      • 1970-01-01
      相关资源
      最近更新 更多