6

尝试按照本 Hibernate 教程中的步骤 #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 包并按照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错误?

我究竟做错了什么?

4

3 回答 3

14

首先,您的 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>
于 2012-12-17T23:08:54.383 回答
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 系统设置进行设置。

于 2012-12-17T22:32:50.657 回答
1

我建议从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 服务器了。建议将您当前的项目与新下载的项目进行比较。它应该可以解决您的问题。

于 2012-12-17T21:52:58.600 回答