今天写页面的时候,发生了离奇的错误,明明语句在数据库中执行能查出6个字段,但是返回数据时只剩5个了,检查了好多遍代码,终于发现ResultSetmetaData的一点使用心得。
public List<Map<String,Object>> search(String sql){
Connection conn = getConnection();
PreparedStatement ps = null;
List<Map<String,Object>> list = new ArrayList<Map<String,Object>>();
ResultSet rs = null;
try {
ps = conn.prepareStatement(sql);
rs = ps.executeQuery();
ResultSetMetaData md = rs.getMetaData();
int colomn = md.getColumnCount();
Map<String,Object> temp = null;
while(rs.next()) {
temp = new HashMap<String,Object>();
md = rs.getMetaData();
for(int i = 1; i <= colomn; i++) {
temp.put(md.getColumnName(i), rs.getObject(i));
}
list.add(temp);
}
}catch(Exception e) {
e.printStackTrace();
}finally {
closeConnection(conn);
}
return list;
}
ResultSetMetaData有两个方法获取字段名称
一、getColumnName(int index),这个方法获取的是该字段在表内的名称。
二、getConlumnLabel(int index),这个方法获取的是你在语句中要求的该字段的名称
因为我是两张表联合查询,两表中均出现了“name”字段,所以查出来6个字段,执行了一下temp.put就只剩下5个了。