2

これまでのところ、次のコード スニペットがあります。

Sql2o sql2o = new Sql2o("jdbc:sqlite:test.db");

try (Connection connection = sql2o.open()) {
    for (Column column : connection.createQuery("SELECT * FROM sometable").executeAndFetchTable().columns())
        System.out.println(column.toString());
}

私はこれらの依存関係を使用しています:

<dependency>
    <groupId>org.sql2o</groupId>
    <artifactId>sql2o</artifactId>
    <version>1.5.4</version>
</dependency>
<dependency>
    <groupId>org.xerial</groupId>
    <artifactId>sqlite-jdbc</artifactId>
    <version>3.15.1</version>
</dependency>

ただし、これは実行時に NoInitialContextException をスローします。スタックトレース:

Exception in thread "main" java.lang.RuntimeException: javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file:  java.naming.factory.initial
        at org.sql2o.JndiDataSource.getJndiDatasource(JndiDataSource.java:27)
        at org.sql2o.Sql2o.<init>(Sql2o.java:36)
        at me.mypackage.sqlitetest.SqliteTest.main(SqliteTest.java:11)
Caused by: javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file:  java.naming.factory.initial
        at javax.naming.spi.NamingManager.getInitialContext(Unknown Source)
        at javax.naming.InitialContext.getDefaultInitCtx(Unknown Source)
        at javax.naming.InitialContext.getURLOrDefaultInitCtx(Unknown Source)
        at javax.naming.InitialContext.lookup(Unknown Source)
        at org.sql2o.JndiDataSource.getJndiDatasource(JndiDataSource.java:24)
        ... 2 more

この問題を解決するにはどうすればよいですか?

4

1 に答える 1

5

この行を置き換えてみてください

Sql2o sql2o = new Sql2o("jdbc:sqlite:test.db");

Sql2o sql2o = new Sql2o("jdbc:sqlite:test.db", null, null);

このSql2oクラスには単一の文字列のみを受け取るコンストラクターがありますが、その単一の文字列は JDBC 接続 URL ではなく JNDI 名です。接続 URL、ユーザー名、パスワードの 3 つの文字列を取る別のコンストラクターがあります。SQLite はユーザー名とパスワードを使用しないため、null両方の値を指定できます。

于 2016-11-22T22:04:52.143 に答える