如何过滤列表中特定元素的值?

时间:2013-01-28 18:25:29

标签: google-app-engine jdo datanucleus

使用GAE-Java-JDO,是否可以过滤列表中特定元素的值?

工作原理

通常,我会有以下内容:

@PersistenceCapable
class A {

  String field1;
  String field2;

  // id, getters and setters

}

然后我会构建一个简单的查询:

Query q = pm.newQuery(A.class, "field1 == val");
q.declareParameters("String val");
List<A> list = new ArrayList<A>((List<A>) q.execute("foo"));

我想要什么

以上工作正常。但我想要的是存储在列表中的所有字段:

@PersistenceCapable
class AA {

  ArrayList<String> fields;

  // id, getters and setters

}

然后能够查询列表中的特定字段:

int index = 0;
Query q = pm.newQuery(A.class, "fields.get(index) == val");
q.declareParameters("int index, String val");
List<A> list = new ArrayList<A>((List<A>) q.execute(index, "foo"));

但这引发了一个例外:

org.datanucleus.store.appengine.query.DatastoreQuery$UnsupportedDatastoreFeatureException:
Problem with query 
<SELECT FROM xxx.AA WHERE fields.get(index) == val PARAMETERS int index, String val,>:     
Unsupported method <get> while parsing expression: 
InvokeExpression{[PrimaryExpression{strings}].get(ParameterExpression{ui})}

我对阅读the GAE-JDO doc的印象是,这是不可能的:

  

“属性值必须由应用程序提供;它不能引用或以其他属性计算”

所以...任何想法?

提前致谢!

1 个答案:

答案 0 :(得分:0)

如果你只需要按索引+值进行过滤,那么我认为在实际列表值前加上它们的索引前缀应该有效。 (如果您还需要按实际值过滤,则需要存储两个列表。)

即。而不是相当于

带有query-filter fields= ['foo', 'bar', 'baz]

fields[1] == 'bar'

你有

带有query-filter fields= ['0-foo', '1-bar', '2-baz']

fields == '1-bar'

(但在java中)