深入探讨JDBC往MySQL中插入Timestamp类型字段报错问题

本文深入探讨了在使用Apache DBUtils操作MySQL时遇到的空指针异常问题,原因是MySQL 5.1.47驱动包中的Bug。通过分析源码,作者发现问题出在`setParameterMetaData`方法,该问题在回滚到5.1.46版本后得到解决。此外,文章指出,原生JDBC代码不受此Bug影响,除非调用了有问题的方法。
摘要由CSDN通过智能技术生成

背景描述

最近处于工作需要,用到了Apache的commons dbutils包来操作数据库。在保存数据到MySQL数据库时,报了一个空指针异常,作为开发多年的Java老鸟,最不怕的就是空指针异常,于是打上断点开始Debug,发现报错那行代码对象、传入方法中的参数竟然都不为空。。。

问题描述

不废话,直接上代码

问题代码

@Test
public void testDbutilsDateType() {
   
    Connection connection = DBUtils.getConnection();
    String sql = "insert into test (username, nickname, password, createtime) values (?,?,?,?)";
    QueryRunner qr = new QueryRunner();
    try {
   
       // 报错的48行
       int effectRows = qr.update(connection, sql, "lisi", "李四", "456", new Timestamp(System.currentTimeMillis()));
        System.out.println("影响行数:" + effectRows);
    } catch (SQLException e) {
   
        e.printStackTrace();
    } finally {
   
        try {
   
            connection.close();
        } catch (SQLException e) {
   
            e.printStackTrace();
        }
    }
}

报错信息

java.lang.NullPointerException
	at com.mysql.jdbc.PreparedStatement.setTimestamp(PreparedStatement.java:4241)
	at com.mysql.jdbc.PreparedStatement.setObject(PreparedStatement.java:3591)
	at com.mysql.jdbc.JDBC42PreparedStatement.setObject(JDBC42PreparedStatement.java:68)
	at org.apache.commons.dbutils.AbstractQueryRunner.fillStatement(AbstractQueryRunner.java:374)
	at org.apache.commons.dbutils.QueryRunner.update(QueryRunner.java:527)
	at org.apache.commons.dbutils.QueryRunner.update(QueryRunner.java:444)
	at com.john.demo.jdbc.TestJDBC.testDbutilsDateType(TestJDBC.java:48)

排查步骤

  1. 首先我把报错的第48行代码做了排查

     int effectRows = qr.update(connection, sql, "lisi", "李四", "456", new Timestamp(System.currentTimeMillis(
  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值