使用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的印象是,这是不可能的:
“属性值必须由应用程序提供;它不能引用或以其他属性计算”
所以...任何想法?
提前致谢!
答案 0 :(得分:0)
如果你只需要按索引+值进行过滤,那么我认为在实际列表值前加上它们的索引前缀应该有效。 (如果您还需要按实际值过滤,则需要存储两个列表。)
即。而不是相当于
带有query-filterfields= ['foo', 'bar', 'baz]
的 fields[1] == 'bar'
你有
带有query-filterfields= ['0-foo', '1-bar', '2-baz']
的 fields == '1-bar'
(但在java中)