반품 수를 제한하려면 어떻게합니까?


113
myModel.find({}, function(err, items) {
    console.log(items.length);    // Big number
});

반품 된 품목을 삽입 된 최근 10 개 품목으로 제한하려면 어떻게해야합니까?

답변:


188

최신 몽구스 (작성 당시 3.8.1)에서는 두 가지를 다르게 수행합니다. ) execFind ()가 사라지고 대신 exec ()로 대체되었습니다. 따라서 몽구스 3.8.1을 사용하면 다음과 같이 할 수 있습니다.

var q = models.Post.find({published: true}).sort({'date': -1}).limit(20);
q.exec(function(err, posts) {
     // `posts` will be of length 20
});

또는 다음과 같이 간단히 연결할 수 있습니다.

models.Post
  .find({published: true})
  .sort({'date': -1})
  .limit(20)
  .exec(function(err, posts) {
       // `posts` will be of length 20
  });

{ 'date': -1}은 무엇을 의미합니까? 미리 감사드립니다!
kurumkan

3
@ArslArsl-결과가 내림차순으로 날짜별로 정렬됩니다.
NL Long

@ArslArsl 다음과 유사합니다 { date: 'desc' } {date: 'descending'}.. 이 참조 대답을
로티 미 최고의

한도에 대한 최대 값이 있습니까?
lukas_o

20

이와 같이 .limit () 사용 :

var q = models.Post.find({published: true}).sort('date', -1).limit(20);
q.execFind(function(err, posts) {
  // `posts` will be of length 20
});

2
고마워요, 그런 질문을 할 수 있는지 몰랐습니다. 이 execFind 메서드에 대한 문서 형식은 어디에서 찾을 수 있습니까?
Running Turtle

솔직히, 나는 몽구스 소스와 물건, 그리고 테스트 케이스의 예제를 봅니다. 메일 링리스트도 좋습니다. 실제 문서는 약간 구식 인 것 같습니다.
kcbanner 2011

1
execFind는 여전히 mongoosejs의 최신 버전에 있습니까?
Manny

2
@Manny 아니에요. 업데이트 된 버전은 marni의 답변을 참조하십시오.
JohnnyHK

15

나는 조금 게으 르기 때문에 간단한 것을 좋아합니다.

let users = await Users.find({}, null, {limit: 50});

8
models.Post.find({published: true}, {sort: {'date': -1}, limit: 20}, function(err, posts) {
 // `posts` with sorted length of 20
});

5
이 코드는에 대한 설명을 포함하여 문제 해결 수 있지만 방법이유를 이 해결할 수있는 문제가 문제가 정말 도움이 될 게시물의 품질을 향상시킬 수 있습니다. 지금 질문하는 사람뿐만 아니라 미래에 독자를 위해 질문에 답하고 있다는 것을 기억하십시오! 제발 편집 설명을 추가하고, 제한 및 가정이 적용 무엇의 표시를 제공하는 답변을.
Toby Speight 2017

2

매개 변수 찾기

함수 찾기 매개 변수는 다음과 같습니다.

  1. 조건 «Object».
  2. «Object|String»반환 할 [projection] 선택적 필드, Query.prototype.select () 참조
  3. [옵션] «Object»선택 사항은 Query.prototype.setOptions () 참조
  4. [콜백] «Function»

제한하는 방법

const Post = require('./models/Post');

Post.find(
  { published: true }, 
  null, 
  { sort: { 'date': 'asc' }, limit: 20 },
  function(error, posts) {
   if (error) return `${error} while finding from post collection`;

   return posts; // posts with sorted length of 20
  }
);

추가 정보

Mongoose를 사용하면 다음과 같은 다양한 방법으로 컬렉션을 쿼리 할 수 ​​있습니다. 공식 문서

// named john and at least 18
MyModel.find({ name: 'john', age: { $gte: 18 }});

// executes, passing results to callback
MyModel.find({ name: 'john', age: { $gte: 18 }}, function (err, docs) {});

// executes, name LIKE john and only selecting the "name" and "friends" fields
MyModel.find({ name: /john/i }, 'name friends', function (err, docs) { })

// passing options
MyModel.find({ name: /john/i }, null, { skip: 10 })

// passing options and executes
MyModel.find({ name: /john/i }, null, { skip: 10 }, function (err, docs) {});

// executing a query explicitly
var query = MyModel.find({ name: /john/i }, null, { skip: 10 })
query.exec(function (err, docs) {});

// using the promise returned from executing a query
var query = MyModel.find({ name: /john/i }, null, { skip: 10 });
var promise = query.exec();
promise.addBack(function (err, docs) {});

1

어떤 이유로 나는 제안 된 답변과 함께 작동하도록 만들 수 없었지만 select를 사용하여 나를 위해 일한 다른 변형을 발견했습니다.

models.Post.find().sort('-date').limit(10).select('published').exec(function(e, data){
        ...
});

API가 변경되었을 수 있습니까? 버전 3.8.19를 사용하고 있습니다.


1

... 추가적으로 다음을 사용하십시오.

mongoose.Promise = Promise;

이것은 몽구스 약속을 네이티브 ES6 약속으로 설정합니다. 이 추가 없이는 다음을 얻었습니다.

DeprecationWarning : Mongoose : mpromise (mongoose의 기본 promise 라이브러리)는 더 이상 사용되지 않습니다. 대신 자신의 promise 라이브러리를 연결하십시오. http://mongoosejs.com/docs/promises.html

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.