1

鉴于下面的代码,当最后的 if-else 语句进入 else 子句时,是否有某种原因,如果我取消注释这两行代码并注释“FOOZANAZABAR”和“TESTCAIRO”行,它不会添加那些行到 LinkedHashSet 中?它似乎添加了 values.add(new BigDecimal(PEUNIT).multiply(new BigDecimal(1000)).toString()); 当逻辑进入 else 子句时正确,但不会将 BD.ZERO 或 PEFAMT 添加到该字段,尽管它们是字符串。

需要注意的是,ZERO 和 PEFAMT 是 BigDecimal,它们被转换为字符串。这是唯一让我感到悲伤的两个价值观。任何方向将不胜感激。

public static LinkedHashMap<String, LinkedHashSet<String>> convertTransactionTableData(ResultSet rs) {
    LinkedHashMap<String, LinkedHashSet<String>> returnableMap = new LinkedHashMap<String, LinkedHashSet<String>> ();

    try {
        while (rs.next()){
            String PEFAMT, PEPOLN, MCISST, PEBRCD, PEEFFY, PEPLAN;
            String PEUNIT, PETRNC, PECO, PEITYP, ZERO;

            PEPOLN = rs.getString("PEPOLN");
            MCISST = rs.getString("MCISST");
            PEBRCD = rs.getBigDecimal("PEBRCD").toString();
            PEEFFY = rs.getBigDecimal("PEEFFY").toString();
            PEPLAN = rs.getString("PEPLAN");
            PEUNIT = rs.getBigDecimal("PEUNIT").toString();
            PEFAMT = rs.getBigDecimal("PEFAMT").toString();
            PETRNC = rs.getString("PETRNC");
            PECO = rs.getString("PECO");
            PEITYP = DataConverter.resetInsuranceType(rs.getString("PEITYP"));
            ZERO = BigDecimal.ZERO.toPlainString();

            String policyNumber = PEPOLN;
            LinkedHashSet<String> values = new LinkedHashSet<String>();
            values.add(MCISST);
            values.add(PEBRCD);
            values.add(PEEFFY);
            values.add(PEPLAN);
            values.add(PEUNIT);
            if (PEPLAN.equalsIgnoreCase("HSRE")) {
                values.add(new BigDecimal(PEUNIT).multiply(new BigDecimal(1000)).toString());
            } else {
                values.add(PEFAMT);
            }
            values.add(PETRNC);
            values.add(PECO);
            values.add(PEITYP);
            if (DataConverter.testStringToInt(PETRNC)) {
                if (Integer.valueOf(PETRNC) >= 20 && Integer.valueOf(PETRNC) <= 29) {
                    values.add(PEFAMT);
                    values.add(ZERO);
                    values.add(ZERO);
                } else {
                    values.add("FOOZANZABAR");
                    values.add("TESTCAIRO");
//                      values.add(ZERO);
//                      values.add(PEFAMT);
                    values.add(new BigDecimal(PEUNIT).multiply(new BigDecimal(1000)).toString());
                }
            }
            returnableMap.put(policyNumber, values);
        }
    } catch (SQLException sqlEx) {
        logger.error("Problem converting the ResultSet.  ", sqlEx);
    }
    return returnableMap;
}

先感谢您。

  • 乔什
4

1 回答 1

2

请注意,您在此处使用的基础数据结构是SET,这意味着它不会让您添加重复项。BD.ZERO 和 PEFAMT的字符串值很可能已经存在于您的values集合中,因此将被忽略。

如果事实证明是这种情况,只需切换到使用LinkedList<String>允许您重复的情况。

于 2013-04-25T14:24:23.207 回答