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個了。