今天写了一天的MongoDB的索引查询,白天在公司一直没有写出来,主要是对于格式的转化问题,还有 自己的粗心大意,对于mongoDB用shell查询这的显示非常方便的,然后我就在想既然在shell里面可以实现,那么在C#中能不能同样的实现呢?然后动手开敲,感觉自己的效率有些低,今天一天的时间就做出来了一个问题,对于一些复杂的查询我们在找不到代替关键字的情况下可以使用字符串拼接的形式,先拼接出要查询的条件然后转换为BSON格式,(因为拼接的是MongoDB内部的查询,必须进行格式转化) 然后再用find查询就可以了,在项目中就五行代码。现在想起来感觉真的非常简单,,,
突然我想到了在某个大佬博客上看到一句话,大致意思就是说的是,能够支撑敲代码的并不是兴趣,而是当你成功的编译,解决了一个个问题成就感 ,,哈哈哈
加油!!共同成长 ,,有更好的方法欢迎指正
实现方法如下:
我是先在Mongo shell 中直接建的一个模糊查询的索引,然后在webApi 中直接查询出来就可以了,但是一般会在代码中建索引,那么方法也是一样的,不过会多了一行建索引的代码
lperMongodb helperMongodb = new HelperMongodb();
public List<Products> GetProduct(string item)
{
var collection = helperMongodb.GetItemCollection();
//对于Name、Tag的搜索 ( 对于书本搜索 带$,)
var query = "{ $text :{ $search :" + item + "}}";
var filter = BsonSerializer.Deserialize<BsonDocument>(query);
var result = collection.Find(filter).ToList();
return result;
}
对,就是这么简单,里面所说对书本搜索带$符号是因为搜索的是"$《XX》“ 如果带上会产生乱码。