首页 > Java > 正文

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

王林
发布: 2024-02-09 10:57:18
转载
723人浏览过

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
登录后复制

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

白果AI论文
白果AI论文

论文AI生成学术工具,真实文献,免费不限次生成论文大纲 10 秒生成逻辑框架,10 分钟产出初稿,智能适配 80+学科。支持嵌入图表公式与合规文献引用

白果AI论文 61
查看详情 白果AI论文

我想这与找不到 .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网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号