记录跟着小傅哥手敲mybatis源码第四章遇到的小问题

记录跟着小傅哥手敲mybatis源码第四章遇到的小问题

//在下面的代码中,当value类型为timestamp时,执行method = clazz.getMethod(setMethod, Date.class);
//这段代码的意思是通过getMethod方法获取到类clazz中名为setMethod的方法对象。该方法接受两个参数:方法名和参数类型数组。在这里,方法名为setMethod,参数类型为Date.class,表示该方法接受一个Date类型的参数。然后,通过调用getMethod方法返回的方法对象,可以动态地调用类clazz中的setMethod方法,并传入一个Date类型的参数。
//报错信息为:java.lang.NoSuchMethodException:com.cy.rs.service.bugstack_smail_mybatis.User.setCreateTime(java.sql.Date)
//大概意思是没有这个方法,但是在User类中是有这个方法的,并且类型也是Date,注意看报错信息后面的java.sql.Date
//然后我看DefaultSqlSession类型引用的Date是java.sql.Date,而User类中引用的类型却是java.util.Date,我是傻逼,成功解决这个问题
//如果两个类引用的全是java.util.Date的话,成功解决问题
//如果两个类引用的全是java.sql.Date的话,则会在method.invoke(obj, value);这里报错,报错信息为:
//java.lang.IllegalArgumentException: argument type mismatch
private <T> List<T> resultSet2Obj(ResultSet resultSet, Class<?> clazz) {
        List<T> list = new ArrayList<>();
        try {
            ResultSetMetaData metaData = resultSet.getMetaData();
            int columnCount = metaData.getColumnCount();
            // 每次遍历行值
            while (resultSet.next()) {
                T obj = (T) clazz.newInstance();
                for (int i = 1; i <= columnCount; i++) {
                    Object value = resultSet.getObject(i);
                    String columnName = metaData.getColumnName(i);
                    String setMethod = "set" + columnName.substring(0, 1).toUpperCase() + columnName.substring(1);
                    Method method;
                    if (value instanceof Timestamp) {
                        method = clazz.getMethod(setMethod, Date.class);
                    } else {
                        method = clazz.getMethod(setMethod, value.getClass());
                    }
                    method.invoke(obj, value);
                }
                list.add(obj);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return list;
    }

package com.cy.rs.service.bugstack_smail_mybatis;

import java.util.Date;

public class User {

    private Long id;
    private String userId;          // 用户ID
    private String userHead;        // 头像
    private Date createTime;        // 创建时间
    private Date updateTime;        // 更新时间

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getUserId() {
        return userId;
    }

    public void setUserId(String userId) {
        this.userId = userId;
    }

    public String getUserHead() {
        return userHead;
    }

    public void setUserHead(String userHead) {
        this.userHead = userHead;
    }

    public Date getCreateTime() {
        return createTime;
    }

    public void setCreateTime(Date createTime) {
        this.createTime = createTime;
    }

    public Date getUpdateTime() {
        return updateTime;
    }

    public void setUpdateTime(Date updateTime) {
        this.updateTime = updateTime;
    }
}

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值