返品数を制限するにはどうすればよいですか?


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

返されるアイテムを挿入された最新の10アイテムのみに制限するにはどうすればよいですか?

回答:


188

最新のマングース(執筆時点では3.8.1)では、次の2つのことを行います。(1)単一の引数をsort()に渡す必要があります。これは、制約の配列または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}はどういう意味ですか?前もって感謝します!
クルムカン

3
@ArslArsl-結果は日付の降順でソートされます。
NL Long

@ArslArslこれは次のようになります{ date: 'desc' } {date: 'descending'}。この回答を
rotimi-best

上限はありますか?
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メソッドに関するドキュメントはどこにありますか?
亀を走らせる

正直なところ、私はマングースのソースやものの例とテストケースだけを見ています。メーリングリストもいいです。実際のドキュメントは少し古くなっているようです。
kcbanner 2011

1
execFindはまだ最新バージョンのmongoosejsにありますか?
マニー

2
@マニーそうではありません。更新されたバージョンについては、マルニの回答をご覧ください。
JohnnyHK 2013

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

パラメータを見つける

関数findが取るパラメータは次のとおりです。

  1. 条件«Object»
  2. [射影] «Object|String»返すオプションのフィールド。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.