如何使用contains()创建JDO查询?

时间:2011-12-11 00:45:45

标签: java google-app-engine google-cloud-datastore jdo datanucleus

我有一个枚举为实例变量的类:

  public enum Races {
     Human, Elf, Orc, Troll
  }

  @PersistenceCapable(detachable="true")
  public class Crafter {
     @PrimaryKey
     @Persistent(valueStrategy = IdGeneratorStrategy.IDENTITY)
     private Key key;
     @Persistent
     private Races race;
  }

我已经能够存储和检索该类的实例,这不是问题所在。

当我想查询所有的兽人和巨魔时,问题就来了。

  Races[] races = new Races[] { Races.Orc, Races.Troll, };

  Query query = manager.newQuery(Crafter.class);
  query.setFilter(":raceParam.contains(race)");
  List<Crafter> crafters = (List<Crafter>) query.execute(Arrays.asList(races));

它不起作用,我明白了:

    Caused by: java.lang.IllegalArgumentException: race: ca.forklabs.wowtradeskills.web.shared.Races is not a supported property type.
      at com.google.appengine.api.datastore.DataTypeUtils.checkSupportedSingleValue(DataTypeUtils.java:184)
      at com.google.appengine.api.datastore.DataTypeUtils.checkSupportedValue(DataTypeUtils.java:149)
      at com.google.appengine.api.datastore.Query$FilterPredicate.<init>(Query.java:574)
      at com.google.appengine.api.datastore.Query.addFilter(Query.java:260)
      at org.datanucleus.store.appengine.query.DatastoreQuery.addLeftPrimaryExpression(DatastoreQuery.java:1343)
            ...

如何使用JDO和Google App Engine进行IN查询?

一些参考文献:

1 个答案:

答案 0 :(得分:0)

JDOQL中的

包含的定义类似于Java ...在Collection(字段)上。你有一个阵列。 JDOQL语法遵循Java语法