2013-06-15 2 views
1

내 엔티티에서 선택한 필드를 가져 오기 위해 엔드 포인트 클래스에서 표준 선택 쿼리를 수정하려고합니다. 그러나 쿼리를 변경 한 후에도 내 쿼리 결과가 모든 필드를 가져 오는 것으로 나타났습니다. 아래 코드는 내 자신을 추가하도록 쿼리가 업데이트되었음을 ​​나타냅니다. 기본적으로 엔티티의 일부 속성 만 가져 오는 대신 네트워크 데이터 트랜잭션 볼륨을 줄이기 위해 모든 속성을 가져 오는 쿼리를 작성하려고합니다. 어떤 도움을 주셔서 감사합니다. GAE 데이터 저장소에 대한엔티티 포인트 클래스의 엔티티에서 몇 가지 속성을 선택하는 중

//QUERY MODIFIED IN THIS METHOD 
/** 
* This method lists all the entities inserted in datastore. 
* It uses HTTP GET method and paging support. 
* 
* @return A CollectionResponse class containing the list of all entities 
* persisted and a cursor to the next page. 
*/ 
@SuppressWarnings({ "unchecked", "unused" }) 
@ApiMethod(name = "listQuizTable") 
public CollectionResponse<QuizTable> listQuizTable(
     @Nullable @Named("cursor") String cursorString, 
     @Nullable @Named("limit") Integer limit) { 

    EntityManager mgr = null; 
    Cursor cursor = null; 
    List<QuizTable> execute = null; 

    try { 
     mgr = getEntityManager(); 
     //Query query = mgr.createQuery("select from QuizTable as QuizTable"); 

     Query query = mgr.createQuery("select n.quizKey, n.quizDesc, n.uploadDate from QuizTable n"); 

     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<QuizTable>) 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 (QuizTable obj : execute) 
      ; 
    } finally { 
     mgr.close(); 
    } 

    return CollectionResponse.<QuizTable> builder().setItems(execute) 
      .setNextPageToken(cursorString).build(); 
} 
+0

나는 누군가이 쿼리에 대해 투표 한 이유가 무엇인지 궁금합니다. 내가 작성하는대로 Google 앱 엔진과 엔드 포인트는 계속 진화하고 있습니다. Google에는이 문서도 많지 않습니다. stackkoverflow에 이러한 쿼리를 게시하면 downvoting이 발생하면 매우 바람직하지 않습니다. 나는 앱 엔진 백엔드 설정을 시작한 이래로 지난 1 개월 동안 내가 배운 것을 토대로 다른 사용자를 돕기 위해 많은 질문에 답을하고있었습니다. – user1938357

답변

1

Projection queries은 당신의 목적을 제공한다. 쿼리 결과에서 필수 필드 만 반환하고 원하지 않는 필드는 비워 둡니다. 이제 클라우드 종점을 통해 수정 된 응답을 수신하려면 개별 엔터티를 나타내는 응답 항목을 수정하여 엔터티의 모든 필드 대신 필수 필드 만 포함하도록합니다. 그런 다음 수정 된 개별 응답 항목을 반복하여 모음 응답 항목을 만듭니다.

투영 쿼리는 수행 할 수있는 쿼리의 종류에 제한이 있습니다. 예를 들어 결과에 필요한 필드는 같음 필터에서 사용할 수 없습니다. 자신의 경우에 이러한 제한을 두드린 경우 프로젝션 쿼리를 사용하지 않고 바로 두 번째 옵션을 사용할 수 있습니다. 즉, 일반 쿼리를 수행 한 다음 수정 된 개별 및 수집 응답 항목을 사용하여 클라우드 종단점을 통해 필수 필드 만 보내도록합니다.

+0

정말 고맙습니다. 고마워요. 나는 지금 나갈 길을 찾을 수 있어야한다. 엔드 포인트에서이 작업을 수행하는 것이 현재 시도하고있는 유일한 과제이며 제안 사항을 염두에 두십시오. – user1938357

관련 문제