pm1*_*100 25 c# mongodb mongodb-.net-driver
有没有办法将shell查询语法中表达的查询提交给mongo c#驱动程序
例如,像
Coll.find { "myrecs","$query : { x : 3, y : "abc" }, $orderby : { x : 1 } } ");
Run Code Online (Sandbox Code Playgroud)
以shell指南为例
And*_*ich 36
您没有完全相同的功能.
但您可以从json创建BsonDocument以进行查询:
var jsonQuery = "{ x : 3, y : 'abc' }";
BsonDocument doc = MongoDB.Bson.Serialization
.BsonSerializer.Deserialize<BsonDocument>(jsonQuery);
Run Code Online (Sandbox Code Playgroud)
之后,您可以从BsonDocument创建查询:
var query = new QueryComplete(doc); // or probably Query.Wrap(doc);
Run Code Online (Sandbox Code Playgroud)
您可以对排序表达式执行相同的操作:
var jsonOrder = "{ x : 1 }";
BsonDocument orderDoc = BsonSerializer.Deserialize<BsonDocument>(jsonQuery);
var sortExpr = new SortByWrapper(orderDoc);
Run Code Online (Sandbox Code Playgroud)
你也可以像这样为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();
}
Run Code Online (Sandbox Code Playgroud)
我没有测试上面的代码.如果需要,会在以后做.
更新:
刚刚测试了上面的代码,它正在运行!
你可以像这样使用它:
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 }");
Run Code Online (Sandbox Code Playgroud)
小智 17
QueryComplete类似乎已被弃用.请MongoDB.Driver.QueryDocument改用.如下:
BsonDocument document = MongoDB.Bson.Serialization.BsonSerializer.Deserialize<BsonDocument>("{ name : value }");
QueryDocument queryDoc = new QueryDocument(document);
MongoCursor toReturn = collection.Find(queryDoc);
Run Code Online (Sandbox Code Playgroud)
这是我写的一个Web服务函数,您可以通过过滤查询,限制和跳过分页以及您想要的任何集合的排序查询来发送它!它通用且快速.
/// <summary>
/// This method returns data from a collection specified by data type
/// </summary>
/// <param name="dataType"></param>
/// <param name="filter">filter is a json specified filter. one or more separated by commas. example: { "value":"23" } example: { "enabled":true, "startdate":"2015-10-10"}</param>
/// <param name="limit">limit and skip are for pagination, limit is the number of results per page</param>
/// <param name="skip">skip is is the page size * page. so limit of 100 should use skip 0,100,200,300,400, etc. which represent page 1,2,3,4,5, etc</param>
/// <param name="sort">specify which fields to sort and direction example: { "value":1 } for ascending, {"value:-1} for descending</param>
/// <returns></returns>
[WebMethod]
public string GetData(string dataType, string filter, int limit, int skip, string sort) {
//example: limit of 100 and skip of 0 returns the first 100 records
//get bsondocument from a collection dynamically identified by datatype
try {
MongoCollection<BsonDocument> col = MongoDb.GetConnection("qis").GetCollection<BsonDocument>(dataType);
if (col == null) {
return "Error: Collection Not Found";
}
MongoCursor cursor = null;
SortByWrapper sortExpr = null;
//calc sort order
try {
BsonDocument orderDoc = BsonSerializer.Deserialize<BsonDocument>(sort);
sortExpr = new SortByWrapper(orderDoc);
} catch { }
//create a query from the filter if one is specified
try {
if (filter != "") {
//sample filter: "{tags:'dog'},{enabled:true}"
BsonDocument query = BsonSerializer.Deserialize<BsonDocument>(filter);
QueryDocument queryDoc = new QueryDocument(query);
cursor = col.Find(queryDoc).SetSkip(skip).SetLimit(limit);
if (sortExpr != null) {
cursor.SetSortOrder(sortExpr);
}
return cursor.ToJson();
}
} catch{}
//if no filter specified or the filter failed just return all
cursor = col.FindAll().SetSkip(skip).SetLimit(limit);
if (sortExpr != null) {
cursor.SetSortOrder(sortExpr);
}
return cursor.ToJson();
} catch(Exception ex) {
return "Exception: " + ex.Message;
}
}
Run Code Online (Sandbox Code Playgroud)
假设我的集合中有这些记录名为"mytest2":
[{ "_id" : ObjectId("54ff7b1e5cc61604f0bc3016"), "timestamp" : "2015-01-10 10:10:10", "value" : "23" },
{ "_id" : ObjectId("54ff7b415cc61604f0bc3017"), "timestamp" : "2015-01-10 10:10:11", "value" : "24" },
{ "_id" : ObjectId("54ff7b485cc61604f0bc3018"), "timestamp" : "2015-01-10 10:10:12", "value" : "25" },
{ "_id" : ObjectId("54ff7b4f5cc61604f0bc3019"), "timestamp" : "2015-01-10 10:10:13", "value" : "26" }]
Run Code Online (Sandbox Code Playgroud)
我可以使用以下参数进行Web服务调用,以第一页开始返回100条记录,其中值> = 23,值<= 26,按降序排列
dataType: mytest2
filter: { value: {$gte: 23}, value: {$lte: 26} }
limit: 100
skip: 0
sort: { "value": -1 }
Run Code Online (Sandbox Code Playgroud)
请享用!