MongoDB C# / .NET Driver 中IMongoQuery的内部实现Query的用法

来源:互联网 发布:善领dsa最新数据 编辑:程序博客网 时间:2024/05/19 23:04

MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。   

最近做的项目中打算使用。MongoDB C# / .NET Driver

很欣赏这个驱动的IMongoQuery,其中Query的设计很有意思。用法见下。

            Query.All("name", "a", "b");//通过多个元素来匹配数组            Query.And(Query.EQ("name", "a"), Query.EQ("title", "t"));//同时满足多个条件            Query.EQ("name", "a");//等于            Query.Exists("type", true);//判断键值是否存在            Query.GT("value", 2);//大于>            Query.GTE("value", 3);//大于等于>=            Query.In("name", "a", "b");//包括指定的所有值,可以指定不同类型的条件和值            Query.LT("value", 9);//小于<            Query.LTE("value", 8);//小于等于<=            Query.Mod("value", 3, 1);//将查询值除以第一个给定值,若余数等于第二个给定值则返回该结果            Query.NE("name", "c");//不等于            Query.Nor(Array);//不包括数组中的值            Query.Not("name");//元素条件语句            Query.NotIn("name", "a", 2);//返回与数组中所有条件都不匹配的文档            Query.Or(Query.EQ("name", "a"), Query.EQ("title", "t"));//满足其中一个条件            Query.Size("name", 2);//给定键的长度            Query.Type("_id", BsonType.ObjectId );//给定键的类型            Query.Where(BsonJavaScript);//执行JavaScript            Query.Matches("Title",str);//模糊查询 相当于sql中like  -- str可包含正则表达式


原创粉丝点击