java - Java 中的 sql2o 与 SQLite NoInitialContextException

标签 java sqlite sql2o

到目前为止我已经得到了以下代码片段:

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

如何解决这个问题?

最佳答案

尝试替换此行

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

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

Sql2o类有一个仅接受单个字符串的构造函数,但是该单个字符串是 JNDI 名称,而不是 JDBC 连接 URL。还有另一个构造函数采用三个字符串,分别用于连接 URL、用户名和密码。 SQLite 不使用用户名和密码,因此我们可以为它们指定 null 值。

关于java - Java 中的 sql2o 与 SQLite NoInitialContextException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40752052/

相关文章:

Java如何为此字符串设置正则表达式

java - 使用 webviewfragment 更改方向时如何保存 webview 的状态

java - Spring Security 5 Spring MVC Oauth 2密码授予类型不返回带有/oauth/token的 token

java - ORMLite 异常 : java. sql.SQLException: ResultSet 已请求

performance - SQLite删除慢

javascript - 数据库中的信息有多本地化?

java - Gradle:创建具有依赖项的单个JAR

java - 外键始终保持为空

java - 带有postgres的sql2o,查询没有返回结果