Как начать запускать сервер 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 ответа:
Во-первых, ваш путь к классу обычно не корректен для любого 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. Рекомендую сравнить ваш текущий проект с только что загруженным. Это должно решить вашу проблему.