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あり、クラスパスenvvarはそのファイルを指しています。

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変数です。したがって、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 に答える