0

我的代码中有一个查询,它在一个对象中搜索多个 id。在表PreparationPhytoterapic中包含以下字段:(phytoterapicItem_id外键),preparationItem_id(外键)和id。问题是当 apreparationItem_id包含多个条目时,它会再次添加到列表中。

我尝试使用if(!listPreparations.contains(preparationContents2.get(0)))但不起作用。

任何的想法?

        preparationphytoterapicDao = getHelper().getPreparationPhytoterapicDao();
        QueryBuilder<PreparationPhytoterapic, Integer> queryBuilder2 = 
            preparationphytoterapicDao.queryBuilder();
        Where<PreparationPhytoterapic, Integer> where2 = queryBuilder2.where();
        SelectArg selectArg = new SelectArg();
        where2.eq("phytoterapicItem_id", selectArg);
        PreparedQuery<PreparationPhytoterapic> preparedQuery2 = queryBuilder2.prepare();
        List<PreparationPhytoterapic> preparationphytoterapics;
        QueryBuilder<PreparationContent, Integer> queryBuilder3 = 
            preparationContentDao.queryBuilder();
        Where<PreparationContent, Integer> where3 = queryBuilder3.where();
        SelectArg selectArg2 = new SelectArg();
        where3.eq("id", selectArg2);
        PreparedQuery<PreparationContent> preparedQuery3 = queryBuilder3.prepare();
        List<PreparationContent> preparationContents2;
        for(int j = 0; j < listPhytoterapics.size(); j++) {
            selectArg.setValue(listPhytoterapics.get(j).getPhytoterapicItem().getId());
            preparationphytoterapics = preparationphytoterapicDao.query(preparedQuery2);
            if(preparationphytoterapics.size() != 0) {
                for(int k = 0; k < preparationphytoterapics.size(); k++) {
                    selectArg2.setValue(preparationphytoterapics.get(k).getPreparationItem().getId());
                    preparationContents2 = preparationContentDao.query(preparedQuery3);
                    if(!listPreparations.contains(preparationContents2.get(0)))
                        listPreparations.add(preparationContents2.get(0));
                }
            }
4

1 回答 1

1

如果您查看 List.contains(...)方法定义,它会说:

如果此列表包含指定元素,则返回 true。更正式地说,当且仅当此列表包含至少一个元素 e 满足 (o==null ? e==null : o.equals(e)) 时,才返回 true。

我怀疑您没有equals(...)定义完全PreparationContent使用该id字段的方法。我认为这就是你想要的。您需要在对象中包含以下内容。您还需要覆盖hashCode()以使它们对称。

  @Override
  public boolean equals(Object obj) {
      if (obj == null || obj.getClass() != this.getClass()) {
          return false;
      }
      PreparationContent other = (PreparationContent)obj;
      return this.id = other.id;
  }

  @Override
  public int hashCode() {
      // if id is long then return Long.valueOf(id).hashCode();
      return id;
  }
于 2012-06-26T15:23:52.250 回答