直连数据库提示 No suitable driver found for jdbc:postgresql的问题

背景

我参考数据库手册,尝试在代码里使用直连的方式在数据库中创建数据库等,由于需要适配各个数据库服务所以我分别兼容了mysql、postgresql、oracal等。但是在使用过程中会出现错误:

No suitable driver found for jdbc:postgresql

代码大致逻辑如下:

java 复制代码
Connection connection = null;
Statement statement = null;
try {
    connection = DriverManager.getConnection(url, loginUser, loginPwd);
    statement = connection.createStatement();
    //其他代码
} catch (Exception e){
    LOGGER.error("创建数据库信息异常", e);
    result = false;
} finally {
    close(connection, statement);
}

解决方式

在这个问题中,出现了"no suitable driver found for jdbc:postgresql"的错误。这是因为在尝试建立与PostgreSQL数据库的连接时,JDBC DriverManager没有找到合适的驱动程序。

在JDBC中,驱动程序的加载通常是通过类加载器自动完成的,当你引入了PostgreSQL的依赖后,该依赖应该包含了PostgreSQL的JDBC驱动。

经过排查发现DriverManager中的driver列表只有mysql的Driver。没有postgresql的Driver。但是理论上这个Driver的注册都是在类初始化的时候自动注册的。不知道为什么他没有注册到DriverManager里面。

我首先尝试的解决办法是创建一个我们需要的Driver。例如postgresql的:

java 复制代码
Connection connection = null;
Statement statement = null;
try {
    Class clazz = Class.forName("org.postgresql.Driver");
    clazz.newInstance();
    connection = DriverManager.getConnection(url, loginUser, loginPwd);
    statement = connection.createStatement();
    //其他代码
} catch (Exception e){
    LOGGER.error("创建数据库信息异常", e);
    result = false;
} finally {
    close(connection, statement);
}

这样就会自动执行其中的静态代码块,实现注册Driver到DriverManager的目的。

原因

猜测是接手的项目中JDBC版本有点老的原因

在较新版本的 JDBC 规范中,通常不再需要显式调用Class.forName("org.postgresql.Driver")来加载驱动程序。有些老版本的JDBC驱动程序可能还依赖于Class.forName("org.postgresql.Driver")这种手动加载方式。

使用SpringJDBC

但其实后面发现如果直接使用Spring的JDBCTemplate似乎也不会报上面的问题,最后也是使用这种方式来解决的。

Spring JDBC通常会自动处理驱动程序的加载和注册,因此在使用Spring JDBC时,通常不需要显式调用Class.forName("org.postgresql.Driver")来手动加载驱动程序。Spring JDBC框架会在初始化时自动检测classpath中的JDBC驱动程序,并将其注册到DriverManager中。这样,在您使用Spring JDBC创建数据库连接时,Spring框架会自动选择合适的驱动程序,并建立连接,而无需开发者手动加载驱动程序。

相关推荐
她的男孩2 小时前
Spring Boot 接 Flowable 工作流:用 3 个注解搭一个请假审批流程
java·后端·架构
爱读源码的大都督2 小时前
Claude Code源码分析(三):为什么系统提示词中需要有tools呢?
前端·人工智能·后端
爱勇宝2 小时前
Claude Code 被曝暗藏“隐形检测”代码:封代理不是最可怕的,可怕的是你根本不知道它在干什么
前端·后端·程序员
ITOM运维行者2 小时前
从零搭建企业级服务器监控体系:踩坑实录与架构设计
前端·后端
用户4099322502123 小时前
Vue状态管理入门第四章:组合式store和SSR风险
前端·vue.js·后端
用户34232323763173 小时前
SPI 通信与高速外设驱动详解
后端
魏祖潇3 小时前
SDD 完整指南——Spec 端打底、Story 端交付、留白区
人工智能·后端
feelmylife593 小时前
消息队列可靠投递与幂等消费 -- 从"消息丢了"到"消息别重复"的完整工程实践
后端
雪隐3 小时前
个人电脑玩AI-10让5060 Ti给你打工——部署 Odysseus:终于有个能打的"AI管家"了
人工智能·后端
荣码4 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python