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

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

img

下面是BaseDao中封装的方法

 public  List executeQuery(Class 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 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


应该怎么调用

  • 就是你的实体对象的Class类型,对应你操作的某张表
  • 实体类的成员变量名 对应表中的字段名

参考:https://blog.csdn.net/qq_44895397/article/details/106533341

参考GPT和自己的思路:

调用BaseDao中的executeQuery方法时,需要传入三个参数:一个Class类型的clazz,一个String类型的sql语句,一个Object类型的可变参数params。其中clazz表示要转换成的对象类型(比如说Student.class),sql表示要执行的SQL语句,params表示可变参数,其实就是一些占位符的值,比如"SELECT * FROM student WHERE id=?",那么params中就要传入占位符的具体值,比如1或者"张三"等等。

具体调用方式如下:

List<Student> students = baseDao.executeQuery(Student.class, "SELECT * FROM student WHERE id=?", 1);

其中,Student.class表示要转换成的对象类型,"SELECT * FROM student WHERE id=?"表示要执行的SQL语句,1(这里只传了一个参数)表示占位符的具体值。

在调用executeQuery方法时,可以传入多个参数,比如:

List<Student> students = baseDao.executeQuery(Student.class, "SELECT * FROM student WHERE name=?", "张三");

这里需要注意的是,传入的参数个数要与占位符的个数对应,否则会抛出异常。同时,也需要注意占位符的顺序,要与params数组中元素的顺序一致。

不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^