sql >> Databasteknik >  >> NoSQL >> MongoDB

Kan jag göra en textfråga med mongodb c#-drivrutinen

Det finns ingen exakt samma funktion som du vill ha.

Men du kan skapa BsonDocument från json för fråga:

var jsonQuery = "{ x : 3, y : 'abc' }";
BsonDocument doc = MongoDB.Bson.Serialization
                   .BsonSerializer.Deserialize<BsonDocument>(jsonQuery);

Och efter det kan du skapa en fråga från BsonDocument:

var query = new QueryComplete(doc); // or probably Query.Wrap(doc);

Detsamma kan du göra för sorteringsuttrycket:

var jsonOrder = "{ x : 1 }";
BsonDocument orderDoc = BsonSerializer.Deserialize<BsonDocument>(jsonQuery);

var sortExpr = new SortByWrapper(orderDoc);

Du kan också skapa förlängningsmetod för MongoCollection så här:

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();
}

Jag testade inte koden ovan. Kommer att göra det senare om det behövs.

Uppdatering:

Testade precis koden ovan, den fungerar!

Du kan använda det så här:

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 }");


  1. Sammanlagd $lookup Den totala storleken på dokument i matchande pipeline överstiger den maximala dokumentstorleken

  2. Hur får man array från mongoDB-samlingen?

  3. Automatisering och hantering av databaser med öppen källkod i molnet - Tillkännage ClusterControl 1.6

  4. Skapa en anteckningsapp för Android med MongoDB Stitch