java.sql.SQLException: No suitable driver found for “jdbc:mysql://localhost:3306/****?问题

java.sql.SQLException: No suitable driver found for “jdbc:mysql://localhost:3306/****?useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&serverTimezone=Asia/Shanghai&useSSL=false”;问题

总结:java的properties文件赋值不要写分号,会一起读取进去

背景:在将登录MySQL需要用到的数据封装到jdbc.properties时,

  • 通过静态代码块,加载类时自动执行(读取jdbc.properties中的数据)
public static  String DRIVER ;
public static  String URL;
public static  String USER ;
public static  String PWD ;

static {
    InputStream is = ConnUtil.class.getClassLoader().getResourceAsStream("jdbc.properties");
    Properties properties=new Properties();
    try {
        properties.load(is);
       DRIVER= properties.getProperty("jdbc.DRIVER");
        URL= properties.getProperty("jdbc.URL");
        USER= properties.getProperty("jdbc.USER");
        PWD= properties.getProperty("jdbc.PWD");
    } catch (IOException e) {
        e.printStackTrace();
    }
}

异常:出现加载驱动错误

  • java.sql.SQLException: No suitable driver found for "jdbc:mysql://localhost:3306/qqzonedb2?useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&serverTimezone=Asia/Shanghai&useSSL=false";

原因:java的properties文件不能写分号

  • properties在load()时会将分号一起读取进去

jdbc.properties
实际运行时从jdbc.properties中读取的值

  • 因为jdbc.properties配置文件中的jdbc.DRIVER后面带了一个分号,所以通过load获取的Driver也有一个分号(上面的debug图片)

  • 注意上面的异常最后也是带了一个分号

删去分号,问题解决

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值