首页  >  文章  >  JDBC 和 SQLite - 无论我如何尝试都找不到合适的驱动程序

JDBC 和 SQLite - 无论我如何尝试都找不到合适的驱动程序

王林
王林转载
2024-02-09 10:57:18632浏览

php小编鱼仔在使用JDBC和SQLite时遇到了一个问题,无论如何尝试都找不到合适的驱动程序。JDBC是Java连接数据库的一种标准接口,而SQLite是一种轻量级的嵌入式关系型数据库引擎。然而,尽管JDBC提供了各种数据库的驱动程序,却没有专门为SQLite设计的驱动程序。这让小编陷入了困惑,无法正常连接并操作SQLite数据库。在接下来的文章中,我们将一起探讨解决这个问题的方法。

问题内容

出于学习目的,我尝试制作一个简单的 java 程序并连接到 sqlite 数据库。但无论我怎么努力,我都无法成功。我总是得到 no 适用于 jdbc:sqlite:database.db 的驱动程序。但它应该如此简单。我已经尝试过 maven 存储库中的许多驱动程序。

我已经阅读并理解了这个理论:jdbc api 处理与 jdbc 管理器的通信,而 jdbc 驱动程序处理与数据库的通信。我还了解到,当我运行编译的类文件时,必须向包含数据库驱动程序的 .jar 文件添加类路径。例如,如此处所解释的。

一些教程声称需要使用 class.forname() 注册驱动程序,但 oracle 文档说:

applications no longer need to explicitly load jdbc drivers using class.forname()]

此外,我遵循的 sqlite 教程在运行 drivermanager.getconnection(url); 示例 sqlitetutorial.net 之前从未注册驱动程序

在我的目录 e:project 中我有这些文件:

database.java
database.class
database.db
sqlite-jdbc-3.44.1.0.jar

当我运行编译的类文件时,我在终端窗口(powershell)中使用 java -cp ".;sqlite-jdbc-3.44.1.0.jar" database

这是我的代码:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class DataBase {
    public static void connect() {
        Connection conn = null;
        try {
            String url = "jdbc:sqlite:database.db";
            conn = DriverManager.getConnection(url);
            
            System.out.println("Connection is established");
            
            conn.close();
            System.out.println("Connection closed.");

        } catch (SQLException e) {
            System.out.println(e.getMessage());
        }
    } // End method connect

    public static void main(String[] args) {
         connect();

    } // End of main method
} // End of class

如果我能得到任何帮助来推动我前进,我将不胜感激。

我想这与找不到 .jar 文件有关,但我已经尝试了一切可能的方法:将 .jar 文件的副本放在不同目录中的任何位置,重命名它以使其更简单,在添加时添加多个目录类路径等。我不知道可能缺少什么。

此外,当我尝试在 vscode 中执行相同操作时,通过在“引用库”下添加 .jar 文件,它仍然不起作用。

解决方法

问题是 sqlite jdbc 驱动程序还需要 slf4j-api-1.7.36.jar,详细信息请参见其 github 存储库

换句话说,您还需要将 slf4j-api-1.7.36.jar 放入该目录中并使用:

java -cp ".;sqlite-jdbc-3.44.1.0.jar;slf4j-api-1.7.36.jar" database

在我的机器上这将使它工作:

d:\temp> java -cp ".;sqlite-jdbc-3.44.1.0.jar;slf4j-api-1.7.36.jar" database
slf4j: failed to load class "org.slf4j.impl.staticloggerbinder".
slf4j: defaulting to no-operation (nop) logger implementation
slf4j: see http://www.slf4j.org/codes.html#staticloggerbinder for further details.
connection is established
connection closed.

如果您已将 class.forname("org.sqlite.jdbc") 明确添加到您的应用程序中,您将能够诊断此问题,因为如果没有 slf4-api-1.7.36.jar 则会导致中(我将 class.forname 添加到 main):

Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory
        at org.sqlite.JDBC.<clinit>(JDBC.java:26)
        at java.base/java.lang.Class.forName0(Native Method)
        at java.base/java.lang.Class.forName(Class.java:375)
        at DataBase.main(DataBase.java:23)
Caused by: java.lang.ClassNotFoundException: org.slf4j.LoggerFactory
        at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:641)
        at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:188)
        at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:525)
        ... 4 more

因此,虽然不再需要显式加载驱动程序,但它可以提供额外的故障排除信息。

以上是JDBC 和 SQLite - 无论我如何尝试都找不到合适的驱动程序的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文转载于:stackoverflow.com。如有侵权,请联系admin@php.cn删除