JDBC中BaseDao封装的executeQuery方法中的反射怎么传参
下面是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;
现在要从外部调用此封装方法,
参考: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数组中元素的顺序一致。
不知道你这个问题是否已经解决, 如果还没有解决的话: