1

Datastore Queries 文档中,可以看到使用 Query 对象方法调用设置查询的示例:

Query q = pm.newQuery(Person.class);
q.setFilter("lastName == lastNameParam");
q.setOrdering("height desc");
q.declareParameters("String lastNameParam");
List<Person> results = (List<Person>) q.execute("Smith");

我喜欢这种风格,因为它使每个部分都易于阅读并且易于理解正在做什么。但是,最后他们在实际execute行中为“lastNameParam”传递了值“Smith”。从我的角度来看,为了保持一致,应该有一个setParametersQuery 方法,以便以与声明参数名称相同的方式清楚地说明传递给参数的值。我还没有找到这样的查询方法。一个存在吗?如果没有,是否有充分的理由不这样做?还是我的想法很愚蠢,我的推理没有根据?非常感谢!

4

1 回答 1

1

有一种现有的方法可以做到这一点。该功能setParameter()可用。例如,问题中的代码可以通过以下方式完成:

Query q = pm.newQuery(Person.class);
q.setFilter("lastName == lastNameParam");
q.setOrdering("height desc");
q.declareParameters("String lastNameParam");
q.setParameter("lastNameParam", "Smith");
List<Person> results = (List<Person>) q.execute();

我可能对原始问题的构想很糟糕,因为这与 Google App Engine 或 Google Datastore 几乎没有关系,主要涉及 Java 的 Query 类。无论如何,这是可行的解决方案。

于 2013-04-22T17:42:35.707 回答