mysql数据库用jdk吗_JDK+JDBC+MySQL实例及注意事项

/**

* Using reflection to storage the result from database into Bean class.

*

*/

public static List resultSetToList(ResultSet rs, Class

> cls) {

Method[] methods = cls.getDeclaredMethods();

int methodLength = methods.length;

int index;

Map map = new HashMap();

// record all methods name in a HashMap, for quickly locate.

for (index = 0; index < methodLength; index++) {

map.put(methods[index].getName().toLowerCase(), index);

}

ResultSetMetaData meta = null;

Object obj = null;

List list = new ArrayList();

try {

meta = rs.getMetaData();

int colCount = meta.getColumnCount();

while (rs.next()) {

obj = cls.newInstance();

for (int i = 1; i <= colCount; i++) {

String colName = meta.getColumnName(i);

String setMethodName = "set" + colName;

// System.out.println(setMethodName);

int j = map.get(setMethodName.toLowerCase()); //get index of method array

setMethodName = methods[j].getName();

Object value = rs.getObject(colName);

if(value == null){

continue;

}

try {

Method setMethod = obj.getClass().getMethod(setMethodName, value.getClass());

setMethod.invoke(obj, value);

} catch (Exception e) {

System.out.println(setMethodName + " exception");

e.printStackTrace();

}

}

list.add(obj);

}

} catch (InstantiationException | IllegalAccessException | SQLException e) {

e.printStackTrace();

}

return list;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值