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中文网其他相关文章!