ResultSetMetaData的使用心得

今天寫頁面的時候,發生了離奇的錯誤,明明語句在數據庫中執行能查出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個了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章