Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

C# MongoDB driver only returning 100 results

I am writing a mailing label, and need to print a label for each document.

I have 829 documents on the Collection, but when I retrieve them, I only get 100 documents.

I have this LINQ code:

IMongoCollection Pessoa;
Pessoa = database.GetCollection<Pessoa>(collectionName);

return Pessoa.AsQueryable().ToList();

How to retrieve ALL the documents?

like image 859
Tony Avatar asked Apr 19 '17 14:04

Tony


People also ask

What C is used for?

C programming language is a machine-independent programming language that is mainly used to create many types of applications and operating systems such as Windows, and other complicated programs such as the Oracle database, Git, Python interpreter, and games and is considered a programming foundation in the process of ...

What is C in C language?

What is C? C is a general-purpose programming language created by Dennis Ritchie at the Bell Laboratories in 1972. It is a very popular language, despite being old. C is strongly associated with UNIX, as it was developed to write the UNIX operating system.

What is the full name of C?

In the real sense it has no meaning or full form. It was developed by Dennis Ritchie and Ken Thompson at AT&T bell Lab. First, they used to call it as B language then later they made some improvement into it and renamed it as C and its superscript as C++ which was invented by Dr.

Is C language easy?

Compared to other languages—like Java, PHP, or C#—C is a relatively simple language to learn for anyone just starting to learn computer programming because of its limited number of keywords.


2 Answers

I have 829 documents on the Collection, but when I retrieve them, I only get 100 documents.

I could reproduce the issue on my side, using AsQueryable extension method on IMongoCollection collection.AsQueryable() to find documents in a collection, which always return 100 documents even though I changed Items per page setting to Unlimited on Azure portal.

Setting:

enter image description here

Test code:

enter image description here

Count documents in query explorer:

enter image description here

To query all the documents in a collection, as you mentioned in comment, you could try to call Find method with an empty filter.

like image 189
Fei Han Avatar answered Sep 29 '22 08:09

Fei Han


You're probably being limited by the default cursor BatchSize. You can modify this behaviour passing an AggregateOptions object to the AsQueryable extension and setting the BatchSize property to a large enough value.

public static IMongoQueryable<TDocument> AsQueryable<TDocument>(this IMongoCollection<TDocument> collection, AggregateOptions aggregateOptions = null)
like image 29
D.Rosado Avatar answered Sep 29 '22 08:09

D.Rosado