質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.32%

JavaでSQLite利用時のClassNotFoundExceptionについて

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 424

torimingo

score 66

Java初心者です。
JavaでSQLiteを利用したいのですが、実行時エラー(?)のClassNotFoundExceptionが解決できません。
以下にコードなどを掲載します。

  1 // TestSqlite.java
  2
  3 import java.sql.*;
  4 
  5 public class TestSqlite {
  6     public static void main(String args[]) throws Exception {
  7         Class.forName("org.sqlite.JDBC");
  8         Connection conn = DriverManager.getConnection("jdbc:sqlite::memory:");
  9         Statement stmt = conn.createStatement();
 10         ResultSet rs = stmt.executeQuery("SELECT sqlite_version()");
 11         rs.next();
 12         String row = rs.getString(1);
 13         System.out.println(row);
 14         rs.close();
 15         conn.close();
 16     }
 17 }

■コンパイル
javac --release 8 TestSqlite.java

■実行
java -classpath .:sqlite-jdbc-3.32.1.jar TestSqlite

■エラー
Exception in thread "main" java.lang.ClassNotFoundException: org.sqlite.JDBC
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:264)
    at TestSqlite.main(TestSqlite.java:7)

■フォルダの内容
 TestSqlite.class
 TestSqlite.java
 sqlite-jdbc-3.23.1.jar


海外のサイトなどを調べても、解決できませんでした。
どなたかご存知の方がおられましたら、教えていただけないでしょうか。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • dodox86

    2018/12/15 10:40

    Javaやjdbcドライバーのバージョンによる問題のように見受けられます。バージョン情報を明示すると適切な回答を得られやすくなると思います。
    ("--release"フラグがあるので、Java9以降のように思えますが、Javaのバージョンは?、sqlite-jdbc-3.32.1.jarはどこで入手したものでしょうか? 動作環境はlinuxですか?)

    キャンセル

  • torimingo

    2018/12/15 10:47

    すみません、自己解決いたしました。
    バージョン明記のことなど、アドバイスをありがとうございました。

    キャンセル

回答 2

check解決した方法

0

自己解決しました。
ファイル名を誤って指定していました・・・。
誤) java -classpath .:sqlite-jdbc-3.32.1.jar TestSqlite
正) java -classpath .:sqlite-jdbc-3.23.1.jar TestSqlite

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/12/15 10:48

    3.23.1 までしかダウンロードできないのでおかしいと思いました。解決してよかったです。

    キャンセル

0

classpathの指定の部分でセミコロンを使うべきところをコロンにしているためではないでしょうか。

java -classpath .;sqlite-jdbc-3.32.1.jar TestSqlite

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/12/15 10:39

    ご回答をありがとうございます。
    セミコロンにしてみましたが、動きませんでした・・・。
    linuxを使っているのですが、コロンで正しいようです。
    windowsでは、セミコロンを使うのが正しいようです。

    キャンセル

  • 2018/12/15 10:43

    Windows + Java8で古いsqlite-jdbcで試したところでは動くので、Class.forNameメソッドのバージョン間の動作違いが原因のようです。

    キャンセル

  • 2018/12/15 10:48

    すみません、自己解決いたしました。
    Javaではバージョンの違いを意識しないといけないんですね。
    心に留めておきます。ありがとうございました。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.32%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る