
JDBC——(6)PreparedStatement的使用——针对不同表的查询操作
发布日期:2021-05-07 02:35:32
浏览次数:19
分类:精选文章
本文共 1293 字,大约阅读时间需要 4 分钟。
按照
中的步骤和查询操作类似,只是对象变为Class 类对象,和利用了List
//通用类查询操作 publicList getForList(Class clazz,String sql, Object... args){ Connection conn = null; PreparedStatement ps = null; ResultSet rs = null; try { conn = JDBCUtils.getConnection(); ps = conn.prepareStatement(sql); for (int i = 0; i < args.length; i++) { ps.setObject(i + 1, args[i]); } rs = ps.executeQuery(); // 获取结果集的元数据 :ResultSetMetaData ResultSetMetaData rsmd = rs.getMetaData(); // 通过ResultSetMetaData获取结果集中的列数 int columnCount = rsmd.getColumnCount(); //创建集合对象 ArrayList list = new ArrayList (); while (rs.next()) { T t = clazz.newInstance(); // 处理结果集一行数据中的每一个列:给t对象指定的属性赋值 for (int i = 0; i < columnCount; i++) { // 获取列值 Object columValue = rs.getObject(i + 1); // 获取每个列的列名 // String columnName = rsmd.getColumnName(i + 1); String columnLabel = rsmd.getColumnLabel(i + 1); // 给t对象指定的columnName属性,赋值为columValue:通过反射 Field field = clazz.getDeclaredField(columnLabel); field.setAccessible(true); field.set(t, columValue); } list.add(t); } return list; } catch (Exception e) { e.printStackTrace(); } finally { JDBCUtils.closeResource(conn, ps, rs); } return null; }
发表评论
最新留言
路过,博主的博客真漂亮。。
[***.116.15.85]2025年05月01日 06时39分06秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Learning Python 008 正则表达式-001
2023-01-30
Learning XNA 4.0 第三章(结尾)
2023-01-30
Leedcode12-word-break-i
2023-01-30
Leedcode3- Max Points on a Line 共线点个数
2023-01-30
Leedcode4-sort listnode 归并排序
2023-01-30
Leedcode6-binary-tree-preorder-traversal
2023-01-30
Leedcode7-binary-tree-postorder-traversal
2023-01-30
Leedcode8-reorder-list
2023-01-30
Leedcode9-linked-list-cycle-i
2023-01-30
Leetcode - Permutations I,II
2023-01-30
LeetCode 64. 最小路径和(Minimum Path Sum) 20
2023-01-30
Leetcode 76 最小覆盖子串 java版
2023-01-31
LeetCode 96. Unique Binary Search Trees
2023-01-31
LeetCode Add Two Numbers
2023-01-31
LeetCode AutoX 安途智行专场竞赛题解
2023-01-31
LeetCode House Robber
2023-01-31