0

エンドポイントを使用して、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;
}

どんな助けでも感謝します。

ありがとう、

4

2 に答える 2

2

あなたは置き換えようとするかもしれません:

    for (Room obj : execute)
        ;

    for (Room obj : execute) {
        if( obj.your_property.equal(your_string) ) {
            // do something with new found `obj`, maybe return it
        }
    }

また、おそらくCollectionResponse関数の最後にリターンは必要ありません。

于 2013-03-19T04:01:00.080 に答える