我在Google App Engine应用程序中有一个“消息”类,我想从数据存储区中检索最后一个(最新的)类;喜欢20条最新消息。它看起来很基本,但我不知道如何使用JDO创建这样的查询。
答案 0 :(得分:2)
首先,您必须在每个Message
实体上存储时间戳。然后,当完成时:
public List<Person> get20NewestMessages() {
Query q = new Query("Message")
q.addSort("timestamp", SortDirection.DESCENDING);
PreparedQuery pq = ds.prepare(q);
return pq.asList(FetchOptions.Builder.withLimit(20));
}
编辑正如您所指出的,这使用了低级数据存储区。这是一个试用的JDO示例:
Query query = pm.newQuery(Message.class);
query.setOrdering("timestamp desc");
query.setRange(0, 20);
List<Message> messages = (List) query.execute();
(我没有测试过,它可能无效)
答案 1 :(得分:0)
import javax.jdo.PersistenceManager;
import javax.jdo.Query;
import javax.jdo.Transaction;
...
public List<Message> get20NewestMessages() {
PersistenceManager pm = PMF.get().getPersistenceManager();
Query q = pm.newQuery(Message.class);
q.setOrdering("timestamp desc");
q.setRange(0, 20);
List<Message> messages = (List<Message>) q.execute();
return messages;
}