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中文网其它相关文章!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号