Java 如何循环结果集并将其保存在映射列表中

Java 如何循环结果集并将其保存在映射列表中,java,list,collections,map,hashmap,Java,List,Collections,Map,Hashmap,我试图循环一个结果集,将值存储在Map中,并将Map保存到列表中,但当我执行时,第一次循环我正确地获取了数据,但第二次我接收到两倍的值,如果循环运行第n次,结果我得到n次 下面是代码 List<HashMap<String, String>> value = new ArrayList<HashMap<String, String>>(); PreparedStatement selectStmt; selectStmt = conn.prepar

我试图循环一个结果集,将值存储在Map中,并将Map保存到列表中,但当我执行时,第一次循环我正确地获取了数据,但第二次我接收到两倍的值,如果循环运行第n次,结果我得到n次

下面是代码

List<HashMap<String, String>> value = new ArrayList<HashMap<String, String>>();
PreparedStatement selectStmt;
selectStmt = conn.prepareStatement("select * from ETR_INT_partc_DOCM  where DOCM_TYP_CDE ='22'");
ResultSet result = selectStmt.executeQuery();
while (result.next()) {
    HashMap<String, String> resultValues = new HashMap<String, String>();
    resultValues.put("PARTC_ID", result.getString("PARTC_ID"));
    resultValues.put("FILE_NME", result.getString("FILE_NME"));
    resultValues.put("LOC_ID", result.getString("LOC_ID"));
    resultValues.put("CRTE_DTE", result.getString("CRTE_DTE"));
    resultValues.put("CRTE_BY", result.getString("CRTE_BY"));
    value.add(resultValues);
    System.out.println(value);
    resultValues.clear();
}
genarateXML(value, sheet)
试试这个:

ResultSet result = selectStmt.executeQuery();
HashMap<String, String> resultValues;
while (result.next()) {
    resultValues = new HashMap<String, String>();
    resultValues.put("PARTC_ID", result.getString("PARTC_ID"));
    resultValues.put("FILE_NME", result.getString("FILE_NME"));
    resultValues.put("LOC_ID", result.getString("LOC_ID"));
    resultValues.put("CRTE_DTE", result.getString("CRTE_DTE"));
    resultValues.put("CRTE_BY", result.getString("CRTE_BY"));
    value.add(resultValues);
    System.out.println(value);
}

为什么要调用:resultValues.clear??您刚刚将HashMap添加到值中,然后清除它,然后创建一个新实例?对我来说毫无意义。在我看来,该行似乎是错误的。列表值似乎是类成员,您在每次调用之前都不会清空/清除它。您希望打印值打印出什么?您确定表中没有重复的行吗?你在sysout上得到了什么?也确实不需要清除,因为你每次迭代都要创建一个新的映射。不确定这是否会起作用,因为OP想要一个映射列表我相信我尝试了Paul sugested的方法,但结果仍然是一样的。我反复得到值,例如,对于第一个循环,它打印为文件名,第二次打印[{File_name2,Somthing_2}],{File_name2,Somthing_2}]你是说第二次打印[{File_name2,Somthing_2}],{File_name2,Somthing_2}],而不是[{File_name2,Somthing_2}]?有趣的