我有一个枚举为实例变量的类:
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查询?
一些参考文献:
答案 0 :(得分:0)
包含的定义类似于Java ...在Collection(字段)上。你有一个阵列。 JDOQL语法遵循Java语法