mysql.cj.jdbc.Driver报错或者数据库Nullpointer报错

有时候数据代码怎么看都是正确的但是往数据库里面插入数据的时候会报错很长很长,那么很有可能就是数据连接驱动版本和你的数据库版本不匹配问题。

问题1

Loading classcom.mysql.jdbc.Driver’. This is deprecated. The new driver class iscom.mysql.cj.jdbc.Driver’. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.

 报错信息如上:原因在于你的数据库连接驱动也就是mysql-connector-java这个东西的版本和驱动类不匹配。

下面用一段jdbc操纵数据库的代码为例。

public class JDBCDemo {
    public static void main(String[] args) throws Exception {
        //注册驱动
        Class.forName("com.mysql.jdbc.Driver");

        //连接
        String url = "jdbc:mysql://127.0.0.1:3306/db1?useSSL=false";
        String username = "root";
        String password = "123456";
        Connection conn = DriverManager.getConnection(url, username, password);

        //定义sql
        String sql1 = "insert into stu(name, id) values ('zhangsan', 3);";
        String sql2 = "insert into stu(name, id) values ('lisi', 4);";
        //获取执行sql的对象
        Statement stmt = conn.createStatement();
        try{
            //相当于开启事务
            conn.setAutoCommit(false);
            //执行两次事务
            stmt.executeUpdate(sql1);
            stmt.executeUpdate(sql2);
            //事务提交
            conn.commit();
        }catch (Exception e){
            //如果出错就回滚
            conn.rollback();
            e.printStackTrace();
        }
        //释放资源
        stmt.close();
        conn.close();
    }
}

在注册驱动那里,Class.forName方法意思是使用Class这个类下面的静态方法forName,使用类加载器将com.mysql.jdbc下的Driver加载到内存中。注意,这里面的com.mysql.jdbc是路径名,Driver是类名。

上述Driver类存放在com.mysql.jdbc路径下是在mysql-connector-java 5版本之前,自从mysql-connector-java 8.0.7开始,Driver类被放在了com.mysql.cj.jdbc目录下。

所以从mysql-connector-java 8.0.7开始,注册驱动要写com.mysql.cj.jdbc.Driver

比如说下面我这段druid.properties配置文件中的driverClassName=com.mysql.cj.jdbc.Driver,意思是驱动是com.mysql.cj.jdbc包下的Driver类。

driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/travel?useSSL=false
username=root
password=123456
initialSize=5
maxActive=10
maxWait=3000

问题2

问题描述:发送请求之后没有响应,不报错,但是也无法对数据库进行任何操作。或者报错无法连接数据库或者空指针情况。

原因:连接驱动和数据库版本不匹配。

数据库连接驱动的版本也不是随便选的。在mysql官网的连接驱动8.0.7页面中,我们可以看到官网解释的很清楚

MySQL Connectors and other MySQL client tools and applications now synchronize the first digit of their version number with the (highest) MySQL server version they support. This change makes it easy and intuitive to decide which client version to use for which server version.

mysql的连接驱动版本和数据库版本号的第一个数字是对应的,也就是说,mysql数据库版本号如果是8开头,那么你的连接驱动版本也应该是8开头才对,如果你的mysql版本是5.5,但是你的驱动是8.0.7,那么就会报一些奇怪的错,比如,数据库无法连接,can't connect to the database 

解决方法:

更改驱动版本和数据库版本一致,比如你的mysql是8.0,那么mysql-connector-java就用8.0.7或者更高版本。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值