कोई सटीक वही कार्यक्षमता नहीं है जो आप चाहते हैं।
लेकिन आप क्वेरी के लिए json से BsonDocument बना सकते हैं:
var jsonQuery = "{ x : 3, y : 'abc' }";
BsonDocument doc = MongoDB.Bson.Serialization
.BsonSerializer.Deserialize<BsonDocument>(jsonQuery);
और उसके बाद आप BsonDocument से क्वेरी बना सकते हैं:
var query = new QueryComplete(doc); // or probably Query.Wrap(doc);
वही आप सॉर्ट एक्सप्रेशन के लिए कर सकते हैं:
var jsonOrder = "{ x : 1 }";
BsonDocument orderDoc = BsonSerializer.Deserialize<BsonDocument>(jsonQuery);
var sortExpr = new SortByWrapper(orderDoc);
इसके अलावा आप MongoCollection के लिए विस्तार विधि इस तरह बना सकते हैं:
public static List<T> GetItems<T>(this MongoCollection collection, string queryString, string orderString) where T : class
{
var queryDoc = BsonSerializer.Deserialize<BsonDocument>(queryString);
var orderDoc = BsonSerializer.Deserialize<BsonDocument>(orderString);
//as of version 1.8 you should use MongoDB.Driver.QueryDocument instead (thanks to @Erik Hunter)
var query = new QueryComplete(queryDoc);
var order = new SortByWrapper(orderDoc);
var cursor = collection.FindAs<T>(query);
cursor.SetSortOrder(order);
return cursor.ToList();
}
मैंने उपरोक्त कोड का परीक्षण नहीं किया। जरूरत पड़ने पर बाद में करेंगे।
अपडेट करें:
बस ऊपर दिए गए कोड का परीक्षण किया, यह काम कर रहा है!
आप इसे इस तरह इस्तेमाल कर सकते हैं:
var server = MongoServer.Create("mongodb://localhost:27020");
var collection= server.GetDatabase("examples").GetCollection("SO");
var items = collection.GetItems<DocType>("{ x : 3, y : 'abc' }", "{ x : 1 }");