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

Pobierz wygenerowany skrypt w sterowniku MongoDB C#

EDYCJA:Od wersji 2.0.1 sterownika FindFluent obiekt zwrócony z IMongoCollection.Find ma odpowiedni ToString który obejmuje filtr, ale także projekcję, sortowanie i tak dalej (jeśli dotyczy).

A więc w tym celu:

var findFluent = collection.
    Find(x => hashValues.Contains(x.UrlHash) && x.ProductTopic == topicId,
        new FindOptions {MaxTime = TimeSpan.FromSeconds(1)}).
    Project(x => x.UrlHash).
    Sort(Builders<ProductMapping>.Sort.Descending(x => x.ProductTopic)).
    Skip(6).
    Limit(7);

Console.WriteLine(findFluent);

Wynik będzie następujący:

find({ "UrlHash" : { "$in" : [4, 5, 6, 7, 8] }, "ProductTopic" : 200 }, { "UrlHash" : 1, "_id" : 0 }).
sort({ "ProductTopic" : -1 }).
skip(6).
limit(7).
maxTime(1000)

Cóż, już wiesz, że dokonujesz wyszukiwania, więc zakładam, że chcesz wiedzieć, jak wygląda zapytanie.

Możesz to łatwo zrobić bezpośrednio ze swojego kodu za pomocą IFindFluent.Filter :

BsonDocument filterDocument = findFluent.Filter.Render(
    collection.DocumentSerializer,
    collection.Settings.SerializerRegistry);

Console.WriteLine(filterDocument);

Dane wyjściowe w twoim przypadku (zależy od hashValues i topicId oczywiście):

{ "UrlHash" : { "$in" : [4, 5, 6, 7, 8, 9] }, "ProductTopic" : 200 }


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Jak wykonać kopię zapasową i przywrócić ClusterControl

  2. Renderować podstawowy widok HTML?

  3. Jak używać kombinacji $unset i $set w mongoDB

  4. Monitorowanie bazy danych za pomocą ClusterControl

  5. Zbiorcza aktualizacja dokumentów w MongoDB