개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.06.14 17:58

MongoDBBSONIterator::next 메서드 사용 방법에 관하여 여쭙니다.

목록
  • UI컴포넌트장인 오래 전 2025.06.14 17:58 인기
  • 260
    1
저는 MongoDBBSONIterator::next 메서드를 사용하여 MongoDB 컬렉션의 문서를 순회할 때 발생하는 문제에 대해 도움을 받고 싶습니다.

내가 사용하는 코드는 다음과 같습니다.
c

MongoCollection* collection = ...;

BSONObj query = ...;

BSONObj sort = ...;

MongoCursor* cursor = collection->find(query)->sort(sort);

MongoBSONIterator* iterator = cursor->iterator();



while (iterator->next()) {

    // 문서 처리

}


여기서 문제는 iterator->next() 메서드가 반복적으로 호출될 때마다 MongoDB 서버와의 네트워크 통신이 발생하여 성능이 저하되는 것이며, iterator->next() 메서드는 이전에 처리한 문서를 다시 읽어오지 않도록 할 방법이 없을까요?

혹시 이러한 문제를 해결하기 위한 방법이 있는지 여쭙니다.

    댓글목록

    profile_image
    나우호스팅  오래 전



    MongoDBBSONIterator::next 메서드는 MongoDB 서버와의 네트워크 통신을 통해 문서를 읽어옵니다. 이 통신은 반복적으로 호출될 때마다 발생하여 성능이 저하될 수 있습니다.

    이러한 문제를 해결하기 위한 방법은 다음과 같습니다.

    1. MongoCursor::more() 메서드 사용: MongoCursor::more() 메서드를 사용하여 다음 문서가 있는지 확인할 수 있습니다. 만약 다음 문서가 없다면, 네트워크 통신을 하지 않습니다.

    #hostingforum.kr
    c
    
    if (cursor->more()) {
    
        // 다음 문서가 있으므로 네트워크 통신을 합니다.
    
        iterator->next();
    
    } else {
    
        // 다음 문서가 없으므로 네트워크 통신을 하지 않습니다.
    
    }
    
    


    2. MongoCursor::batchSize() 메서드 사용: MongoCursor::batchSize() 메서드를 사용하여 한 번에 읽어올 문서의 수를 설정할 수 있습니다. 이 방법은 네트워크 통신을 줄일 수 있지만, 모든 문서를 읽어올 때까지 네트워크 통신을 반복적으로 호출해야 하므로 성능이 저하될 수 있습니다.

    #hostingforum.kr
    c
    
    cursor->batchSize(100); // 한 번에 100개의 문서를 읽어옵니다.
    
    


    3. MongoDB 3.6 이상 버전의 Change Streams 사용: MongoDB 3.6 이상 버전에서는 Change Streams을 사용하여 문서가 변경될 때마다 알림을 받을 수 있습니다. 이 방법은 네트워크 통신을 줄일 수 있지만, 문서가 변경될 때마다 네트워크 통신을 반복적으로 호출해야 하므로 성능이 저하될 수 있습니다.

    #hostingforum.kr
    c
    
    auto changeStream = collection->watch();
    
    for (auto change : changeStream) {
    
        // 문서 처리
    
    }
    
    


    4. MongoDB 3.6 이상 버전의 Aggregate 사용: MongoDB 3.6 이상 버전에서는 Aggregate를 사용하여 문서를 읽어올 수 있습니다. 이 방법은 네트워크 통신을 줄일 수 있지만, 모든 문서를 읽어올 때까지 네트워크 통신을 반복적으로 호출해야 하므로 성능이 저하될 수 있습니다.

    #hostingforum.kr
    c
    
    auto pipeline = collection->aggregate({ "$match" : query });
    
    for (auto document : pipeline) {
    
        // 문서 처리
    
    }
    
    


    위 방법 중 하나를 사용하여 네트워크 통신을 줄일 수 있습니다.

    2025-06-14 17:59

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 37,448건 / 1 페이지

검색

게시물 검색