エンドポイントを使用して、Google App Engine データストアからエンティティ (ルーム) を返そうとしています。このメソッド (自動生成) は、データストア内のすべてのエンティティを返します。
@SuppressWarnings({ "unchecked", "unused" })
public CollectionResponse<Room> listRoom(
@Nullable @Named("cursor") String cursorString,
@Nullable @Named("limit") Integer limit) {
EntityManager mgr = null;
Cursor cursor = null;
List<Room> execute = null;
try {
mgr = getEntityManager();
Query query = mgr.createQuery("select from Room as Room");
if (cursorString != null && cursorString != "") {
cursor = Cursor.fromWebSafeString(cursorString);
query.setHint(JPACursorHelper.CURSOR_HINT, cursor);
}
if (limit != null) {
query.setFirstResult(0);
query.setMaxResults(limit);
}
execute = (List<Room>) query.getResultList();
cursor = JPACursorHelper.getCursor(execute);
if (cursor != null)
cursorString = cursor.toWebSafeString();
// Tight loop for fetching all entities from datastore and accomodate
// for lazy fetch.
for (Room obj : execute)
;
} finally {
mgr.close();
}
return CollectionResponse.<Room> builder().setItems(execute)
.setNextPageToken(cursorString).build();
}
これを編集して、プロパティ、文字列に基づいて 1 つのエンティティのみを返すようにします。そのため、文字列をパラメーターとして渡し、データストアで検索して返します。文字列は主キーにはなりません。
編集:
これを試してみましたが、まだ動作しません:
public Room getRoom(@Named("id") String mac) {
EntityManager mgr = null;
Room room = null;
try {
mgr = getEntityManager();
Query query = mgr.createQuery("SELECT * FROM Room WHERE mac_adds IN ('"+mac+"')");
room = (Room) query.getSingleResult();
} finally {
mgr.close();
}
return room;
}
どんな助けでも感謝します。
ありがとう、