4

我正在从数据库中检索一些值,这些值需要添加到列表中,然后根据它们的值添加到具有特定键的 MAP,例如,

row 1   name = "A" category = "1"
row 2   name = "B" category = "2"
row 3   name = "C" category = "1"
row 4   name = "D" category = "3"

我需要将第 1 行和第 3 行放在一个列表中,将第 2 行和第 4 行分别放在一个单独的列表中,然后将这三个列表放入 MAP 并使用类别名称 (1,2,3) 作为 MAP 的键。

MAP
   1 LIST1 (values of 2 rows)
   2 LIST2 (values of 1 row)
   3 LIST3 (values of 1 row)

我不确定如何将它们添加到列表和 MAP。我的限制是,并非每次检索值时都会检索到相同的行,因此每次我可能需要不同数量的列表来保留已检索到的每个类别的值。

我的代码如下,

 ResultSet rs = st.executeQuery(SelectRows);
 Map map = new HashMap();
 if(rs.next())
 {
    item.setRowID(rs.getString("ID"));
    item.setName(rs.getString("Name"));                       
    item.setValue(rs.getString("Value"));
    item.setCat(rs.getString("Cat"));
    if(!map.containsKey(rs.getString("Cat"))){
        map.put(rs.getString("CatID"), new ArrayList());
    }
    map.get(rs.getString("CatID")).add(row);
 }

最后一行遇到此错误>“”方法 add(Rows) 未定义对象类型。即使我将对象添加到列表中,我也会遇到相同的错误,方法 add(List) 未定义对象类型。

4

5 回答 5

8

您需要创建列表映射。当您阅读记录时,如果存在一个键(这里是类别),则将当前行添加到列表中

 Map map = new HashMap()
 for( Row row : resultset ) {
      if(!map.containsKey(row.category)){
            map.put(row.category, new ArrayList());
      }
      map.get(row.category).add(row.name);
  }

更新

问题是您需要在此处指定泛型类型

 Map<String, List<Rows>> map = new HashMap<String, List<Rows>>()
 while( rs.next() ) {
      Rows row = new Rows();
      /*
       * code to initialize the values of row from the record
       */
      String category = rs.getString("Cat");
      if(!map.containsKey(category)){
            map.put(category, new ArrayList<Rows>());
      }
      map.get(category).add(row);
  }
于 2012-09-29T05:42:12.767 回答
3

您可以使用以类别为键的地图,以列表的 ArrayList 作为值。ArrayList 在您添加时会自动更改大小。Map使用 put(key, value) 添加元素。 ArrayList使用 add(element) 或 add(index, element)。

于 2012-09-29T05:24:40.957 回答
3

我建议你在 Map 中使用 Map

Map<Integer, Map<Integer, String>> map = new HashMap<Integer, Map<Integer,String>>();

外部地图将根据行和值的地图进行分类。因此,每次您想根据行查找值时,您都可以轻松完成。

于 2012-09-29T05:29:46.907 回答
0

我们还可以使用数组列表和链接列表以及向量空间。

Map<Integer, ArrayList<class-name(means object)>> map = new HashMap<>();

Map<Integer, Vector<class-name(means object)>> map = new HashMap<>();

Map<Integer, LinkList<class-name(means object)>> map = new HashMap<>();

所以使用其中之一。

于 2017-02-15T20:22:51.730 回答
0

我声明了一个数据类型为 Map 的变量,如下所示:

Map params = new HashMap();

之后,我可以添加一个对象,如下所示:

params.put("id", indicatorId);
于 2018-07-05T01:33:17.883 回答