AMBLE RUM 2023-03-16 22:11 采纳率: 0%
浏览 40

JDBC中BaseDao封装的executeQuery方法中的反射怎么传参

JDBC中BaseDao封装的executeQuery方法中的反射怎么传参

img

下面是BaseDao中封装的方法

 public <T> List<T> executeQuery(Class<T> clazz,String sql,Object...params) throws Exception {
        //        获取连接
        Connection connection = JdbcUtilsV2.getConnection();
        //      4.创建preparedStatement
        PreparedStatement preparedStatement = connection.prepareStatement(sql);
        if (params != null && params.length != 0) {
            for (int i = 1; i <= params.length; i++) {
                preparedStatement.setObject(i, params[i - 1]);
            }
        }
        //      6.发送sql语句
        ResultSet resultSet = preparedStatement.executeQuery();
        //      7.结果集解析
        List<T> list = new ArrayList<>();
//        TODO:metaData 存储当前结果集列的信息对象(可以获取列的名称根据下角标,可以获取列的数量)
        ResultSetMetaData metaData = resultSet.getMetaData();
//        TODO:水平遍历列
        int columnCount = metaData.getColumnCount();
        while (resultSet.next()) {
            T t = clazz.getDeclaredConstructor().newInstance();//调用类的无参构造函数实例化对象
//          一行数据对应一个T类型的对象,
            for (int i = 1; i <= columnCount; i++) {
//                对象的属性值
                Object value = resultSet.getObject(i);
//                获取指定列下角标的列的名称 ResultSetMetaData
                String propertyName = metaData.getColumnLabel(i);//可以获取列的别名
//                通过反射,给对象的属性值进行赋值
                Field field = clazz.getDeclaredField(propertyName);
                field.setAccessible(true);//属性可以设置,打破private私有修饰
                /*
                * 参数一:要赋值的对象 如果属性是静态,第一个参数可以为null
                * 参数二:具体的属性值
                * */
                field.set(t,value);
            }
            list.add(t);
        }
//        关闭资源
        resultSet.close();
        preparedStatement.close();
        if(connection.getAutoCommit()){
//            没有事务可以关闭
            JdbcUtilsV2.freeConnection();
        }
        return list;

现在要从外部调用此封装方法,

img


应该怎么调用

  • 写回答

4条回答 默认 最新

  • Huazie 全栈领域优质创作者 2023-03-16 22:27
    关注
    • 就是你的实体对象的Class类型,对应你操作的某张表
    • 实体类的成员变量名 对应表中的字段名
    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 3月16日

悬赏问题

  • ¥15 CCF-CSP 2023 第三题 解压缩(50%)
  • ¥30 comfyui openpose报错
  • ¥20 Wpf Datarid单元格闪烁效果的实现
  • ¥15 图像分割、图像边缘提取
  • ¥15 sqlserver执行存储过程报错
  • ¥100 nuxt、uniapp、ruoyi-vue 相关发布问题
  • ¥15 浮窗和全屏应用同时存在,全屏应用输入法无法弹出
  • ¥100 matlab2009 32位一直初始化
  • ¥15 Expected type 'str | PathLike[str]…… bytes' instead
  • ¥15 三极管电路求解,已知电阻电压和三级关放大倍数