MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

MongoDB:Jak zwrócić losowe elementy bez Linq? (MongoDB, C#)

Aby to osiągnąć, możesz użyć struktury agregacji, nie zmieni to sposobu, w jaki zbudowałeś filtr, ponieważ możesz po prostu użyć tego w $match scena.

Obecnie nie ma bezpiecznego dla typu sposobu utworzenia przykładowego etapu (jest to w backlogu Jira CSHARP- 2659 ), jednak możesz po prostu użyć normalnej składni JSON.

var client = new MongoClient();

var db = client.GetDatabase("test");
var collection = db.GetCollection<Person>("people");

// Setup some data
var people = Enumerable.Range(1, 100)
    .Select(x => new Person {Name = $"Person {x}", Age = x});

await collection.InsertManyAsync(people);

var filter = Builders<Person>.Filter.Gt(x => x.Age, 18);
var sampleSize = 10;

// Run aggregation query with a sample stage ($sample)
var personSample = await collection.Aggregate()
    .Match(filter)
    .AppendStage<Person>([email protected]"{{ $sample: {{ size: {sampleSize} }} }}")
    .ToListAsync();

// Output sample
foreach (var person in personSample)
{
    Console.WriteLine($"{person.Name}, Age: {person.Age}");
}

// Example output, note only 10 items all with the matching filter.
// Person 84, Age: 84
// Person 97, Age: 97
// Person 35, Age: 35
// Person 40, Age: 40
// Person 69, Age: 69
// Person 28, Age: 28
// Person 79, Age: 79
// Person 31, Age: 31
// Person 20, Age: 20
// Person 64, Age: 64

Więcej informacji na temat etapu $sample znajdziesz w dokumentacji MongoDB, https://docs.mongodb.com/manual/reference/operator/aggregation/sample/



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Jak wypełnić obiekt mając tablicę obiektu w manguście?

  2. Jak przekazać argument do Mongo Script

  3. BadYieldError podczas używania silnika find() [MongoDB + Tornado]

  4. zbieranie danych grupowych według wielu pól mongodb

  5. model mongoose .js bez eksportu, wymagający w innym folderze nadal działającego schematu