Как начать запускать сервер HSQLDB, как описано в учебнике 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.9hsqldb-2.2.9hsqldblib, и путь к классу env var указывает на него:

CLASSPATH=C:hsqldb-2.2.9hsqldb-2.2.9hsqldblib

Так почему же я получаю это ClassNotFoundException: org.hsqldb.Ошибка сервера ?

Что я делаю не так?

3 5

3 ответа:

Во-первых, ваш путь к классу обычно не корректен для любого jar. Необходимо указать имя jar, например:

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

Во-вторых, CLASSPATH не является необходимым для этого учебника, так как это проект Maven. Вы должны добавить соответствующую зависимость в pom.xml-файл, описанный в разделе 1.1.1 упомянутого вами руководства. Просто добавьте этот блок к тем, которые перечислены в pom.xml, внутри вкладки:

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

Согласно http://docs.oracle.com/javase/7/docs/technotes/tools/windows/classpath.html , вам нужно указать весь путь, заканчивающийся на .кувшин. Если есть несколько файлов jar, возможно, попробуйте указать C:\path\to\hibernate*.jar

Если вы указываете только каталоги, то только *.загружаются файлы классов.

Другой возможностью является переменная CLASSPATH, которую вы устанавливаете только допустимой для сеанса оболочки, а не глобально-следовательно, команда maven не читает ее. Попробуйте установить его через Windows параметры системы.

Я бы рекомендовал загрузить свежую копию учебника из http://sourceforge.net/projects/hibernate/files/hibernate3/3.3.2.GA/ и попытаться построить его. Если вы будете пропускать dependendiens, такие как hsqldb или commons-logging и другие, я решил эту проблему, добавив Maven Project repository - https://repository.jboss.org/nexus/content/repositories/thirdparty-releases . после загрузки всех артефактов я смог запустить сервер HSQLDB. Рекомендую сравнить ваш текущий проект с только что загруженным. Это должно решить вашу проблему.