>웹 프론트엔드 >JS 튜토리얼 >MongoDB 및 Q 약속을 사용하여 루프에서 결과를 반환하기 전에 데이터베이스 쿼리가 완료되었는지 확인하는 방법은 무엇입니까?

MongoDB 및 Q 약속을 사용하여 루프에서 결과를 반환하기 전에 데이터베이스 쿼리가 완료되었는지 확인하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-10 17:34:031037검색

How to Ensure Database Queries Finish Before Returning Results in a Loop with MongoDB and Q Promises?

루프에서 수행된 데이터베이스 쿼리에서 검색된 결과를 반환할 때 발생하는 문제

이 쿼리의 목표는 한 번에 여러 MongoDB 쿼리를 만드는 것입니다. 결합된 결과를 루프하고 단일 데이터 배열로 보냅니다. 그러나 루프 내에서 return을 사용하면 데이터베이스 요청이 완료될 때까지 기다리지 않으므로 정의되지 않은 응답이 발생합니다. Q.moulde를 사용해도 문제가 해결되지 않습니다.

수정코드:

var getPrayerInCat = function(data){
    var promises = data.map(function(data2){
        var id = data2.id;
        return Q.nbind(Prayer.find, Prayer)({prayerCat:id})
            .then(function(prayer) {
                if(!prayer) data2.prayersCount = 0;
                else data2.prayersCount = prayer.length;
                return data2;
            })
    });
    return Q.all(promises);
}

설명:

  1. Q.nbind: 이 함수는 Prayer.find 메소드를 Q 약속을 반환하는 함수로 변환합니다.
  2. 체인 약속: 루프는 이제 업데이트된 데이터 객체로 해결되는 Promise를 반환합니다.
  3. Q.all: 이 함수는 모든 Promise를 업데이트된 모든 데이터 객체가 포함된 배열로 해결되는 단일 Promise로 결합합니다. 모든 데이터베이스 쿼리가 완료되면
  4. return Q.all(promises);: 이 줄은 함수가 모든 데이터베이스 쿼리가 완료될 때까지 기다리고 결합된 결과를 반환하도록 합니다.

위 내용은 MongoDB 및 Q 약속을 사용하여 루프에서 결과를 반환하기 전에 데이터베이스 쿼리가 완료되었는지 확인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.