支持的where字句(比较多,今天先写一部分)

本节介绍支持的where字句

正如前面提到的,不是所有的C#表达式都支持where子句。您可以以此文为指导,或者你可以尝试表达,看看它是否工作(如果不支持,抛出运行时异常,)。

Where字句通常使用where查询操作运算符来介绍,但是在某些情况下,我们必须通过&&合并使用它。

注意:

在1.4版本中还有些限制,但是之后的版本已经解除了,所以在此不再翻译。

  • && (与操作)

子表达式可以通过&&合并来查询满足所有子表达式的文档

var query =

    from c in collection.AsQueryable<C>()

    where c.X >  && c.Y > 

    select c;

// or

var query =

    collection.AsQueryable<C>()

    .Where(c => c.X >  && c.Y > );

上面语句可转化为下述mongodb查询语句

{ X : { $gt : 0 }, Y : { $gt : 0 } }

  

在某些情况下我们也可以使用$and操作符,如下面例子:查询c.X被2整除同时被3整除的文档对象:

var query =

    from c in collection.AsQueryable<C>()

    where (c.X %  == ) && (c.X %  == )

    select c;

// or

var query =

    collection.AsQueryable<C>()

    .Where(c => (c.X %  == ) && (c.X %  == ));

上面例子可以转化为下面使用了 $and的mongodb查询语句

{ $and : [{ X : { $mod : [2, 0] } }, { X : { $mod : [3, 0] } }] }

  

  • Any

这个方法是用来测试集合中字段或属性是否包含任何项。

var query =

    from c in collection.AsQueryable<C>()

    where c.A.Any()

    select c;

// or

var query =

    collection.AsQueryable<C>()

    .Where(c => c.A.Any());

如果A存在一个或者多个项,则会匹配。

可转化为下面mongodb查询语句

{ A : { $ne : null, $not : { $size : 0 } } }

  

  • Any (含谓词)

这个方法用来测试集合中所有项,它会产生一个$elemMatch条件:

var query =

    from c in collection.AsQueryable<C>()

    where c.A.Any(a => a.B == )

    select c;

// or

var query =

    collection.AsQueryable<C>()

    .Where(c => c.A.Any(a => a.B == ));

可转化为下面mongodb查询语句:

{ A : { $elemMatch : { B : 1 } } }

  

  • Boolean 常量

这种形式主要是完整性。你可能会使用很少。它使用一个布尔常数来匹配或不匹配文档。

var query =

    from c in collection.AsQueryable<C>()

    where true

    select c;

// or

var query =

    collection.AsQueryable<C>()

    .Where(c => true);

可转化为下面mongodb查询语句:

{ _id : { $exists : true } }

  

将匹配所有文档,因为_id是必填字段

  • Boolean 字段或属性

一个布尔值的字段或属性的文档没有必要和true进行比较,因为它本身已经在where的时候隐式的和true进行了比较。

var query =

    from c in collection.AsQueryable<C>()

    where c.B

    select c;

// or

var query =

    collection.AsQueryable<C>()

    .Where(c => c.B);

可转化为下面mongodb查询语句:

{ B : true }

  

  • Contains (可枚举的方法)

根据上下文这个方法有两种用法

1.测试一个集合中的字段或者属性是否包含一个特定的值:

. var query =

.     from c in collection.AsQueryable<C>()
. where c.A.Contains()
. select c;
. // or . var query = . collection.AsQueryable<C>()
. .Where(c => c.A.Contains());

可转化为下面mongodb查询语句:

{ A : 123 }

  

这个转换依赖于mongodb查询语言对集合项中字段的处理方式

2.测试一个字段或者属性是否包含在一个集合中

 var local = new [] { , ,  };

var query =
from c in collection.AsQueryable<C>()
where local.Contains(c.A)
select c;
// or
var query =
collection.AsQueryable<C>()
.Where(c => local.Contains(c.A));

可转化为下面mongodb查询语句:

{ A : { $in : [1, 2, 3] } }

  

  • Contains (字符串方法)

这个方法用来筛选对象字符串类型的字段或者属性是否包含一个特定的子串:

var query =

    from c in collection.AsQueryable<C>()

    where c.S.Contains("abc")

    select c;

// or

var query =

    collection.AsQueryable<C>()

    .Where(c => c.S.Contains("abc"));

可转化为下面mongodb查询语句:(使用正则表达式):

{ S : /abc/ }

  

  • ContainsAll (LINQ to MongoDB 扩展方法)

这个方法用于筛选集合中项字段或者属性是否包含提供的所有值:

var query =

    from c in collection.AsQueryable<C>()

    where c.A.ContainsAll(new[] { , ,  })

    select c;

// or

var query =

    collection.AsQueryable<C>()

    .Where(c => c.A.ContainsAll(new[] { , ,  }));

可转化为下面mongodb查询语句:

{ A : { $all : [1, 2, 3] } }

  

  • ContainsAny (LINQ to MongoDB 扩展方法)

这个方法用于筛选集合中项的字段或者属性是否包含任何一个提供的值:

var query =

    from c in collection.AsQueryable<C>()

    where c.A.ContainsAny(new[] { , ,  })

    select c;

// or

var query =

    collection.AsQueryable<C>()

    .Where(c => c.A.ContainsAny(new[] { , ,  }));

可转化为下面mongodb查询语句:

{ A : { $in : [, , ] } }
  • Count 方法 (集合数量、长度)

该方法用于筛选一个可枚举的含有特定数量项的字段或者属性。

var query =

    from c in collection.AsQueryable<C>()

    where c.L.Count() == 

    select c;

// or

var query =

    collection.AsQueryable<C>()

    .Where(c => c.L.Count() == );

可转化为下面mongodb查询语句:

{ L : { $size: 3 } }

  

  • Count 属性 (集合长度)

和方法用法一样,生成同样的查询语句

var query =

    from c in collection.AsQueryable<C>()

    where c.L.Count == 

    select c;

// or

var query =

    collection.AsQueryable<C>()

    .Where(c => c.L.Count == );

可转化为下面mongodb查询语句::

{ L : { $size: 3 } }

  剩下的待续。。。

MongoDB学习(翻译3)的更多相关文章

  1. MongoDB学习3

    MongoDB学习(翻译3)   支持的where字句(比较多,今天先写一部分) 本节介绍支持的where字句 正如前面提到的,不是所有的C#表达式都支持where子句.您可以以此文为指导,或者你可以 ...

  2. MongoDB学习2

    MongoDB学习(翻译2) C#驱动之LINQ教程 介绍 本教程涵盖了1.8发布版本对linq查询的支持. 开始本教程之前,你应该至少阅读下C#驱动教程关于C#驱动的介绍 快速开始 首先,添加下面命 ...

  3. MongoDB学习笔记二- Mongoose

    MongoDB学习笔记二 Mongoose Mongoose 简介 之前我们都是通过shell来完成对数据库的各种操作, 在开发中大部分时候我们都需要通过程序来完成对数据库的操作 而Mongoose就 ...

  4. MongoDB学习笔记系列

    回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助 ...

  5. MongoDB学习笔记—Linux下搭建MongoDB环境

    1.MongoDB简单说明 a MongoDB是由C++语言编写的一个基于分布式文件存储的开源数据库系统,它的目的在于为WEB应用提供可扩展的高性能数据存储解决方案. b MongoDB是一个介于关系 ...

  6. Mongodb学习笔记一(Mongodb环境配置)

    Mongodb学习 说明: MongoDB由databases组成,database由collections组成,collection由documents组成,document由fileds组成.Mo ...

  7. MongoDB学习记录

    一.操作符 "$lt" :"<""$lte" :"<=""$gt" :"> ...

  8. PHP操作MongoDB学习笔记

    <?php/*** PHP操作MongoDB学习笔记*///*************************//**   连接MongoDB数据库  **////*************** ...

  9. MongoDB学习:(二)MongoDB简单使用

    MongoDB学习:(二)MongoDB简单使用 MongoDB使用: 执行mongodb的操作之前,我们需要运行命令,来进入操作命令界面 >mongo 提示该错误,说明我们系统缺少一个补丁,该 ...

  10. MongoDB学习:(一)MongoDB安装

    MongoDB学习:(一)MongoDB安装 MongoDB介绍:     直接百科了: MongoDB安装: 1:下载安装: MongoDB安装:https://www.mongodb.com/do ...

随机推荐

  1. hdu2191 悼念512汶川大地震遇难同胞——珍惜如今,感恩生活

    转载请注明出处:http://blog.csdn.net/u012860063 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2191 Problem ...

  2. unicode编码和中国的相互转换

    如果你的原始文件1.properties(该文件的编码中国).要转换unicode的 在cmd通过进入你在哪里在这种类型的文件夹: native2ascii -encoding gb2312 1.pr ...

  3. C#面向对象复习概要

    1.面向对象:我们将具有统一行为和属性的对象抽象划分为类,通过类去创建对象.这种编程思想叫做面向对象的编程思想. 2.属性:对象具有的属性 using System; using System.Col ...

  4. jquery_mobile.js+html5+css3打造手机平板等各种效果

    http://www.w3school.com.cn/jquerymobile/jquerymobile_events_orientation.asp

  5. linux open

    一直记住不打开文件时候的mode,今天发现原来可以直接用0644这样的八进制数字代替,好开森 #include <stdio.h> #include <sys/types.h> ...

  6. 浙江大学PAT考试1009~1012(1010上帝是冠军。。)

    哎,pat1010即使java书面,只有java书面,还增加了两个点,,.啊,智商捉佳,主要pat有些不给明确的范围.造成遐想空间.. 还是按顺序介绍.. 题目地址:http://pat.zju.ed ...

  7. css中字符换行的一些问题

    -------我们在处理文章的内容的过程中由于文章内容混杂有中文.英文.数字等其他字符,而我们常见的英文和数字是无法在包裹元素中自动换行,这往往会导致元素被撑破,如下图所示: css中word-bre ...

  8. SQL点滴29—错误无处不在

    原文:SQL点滴29-错误无处不在 我只想说以下是很基础的sql知识,但是很容易犯错.所以睁大我们的眼睛,屏住我们的呼吸,小心的检查吧! 案例1if not exists (select OrderI ...

  9. 折腾源WRT的AC路无线路由-2

    在创纪录的开箱图,开箱后,我觉得大尺寸,因此,获得一些各种尺寸,喜欢网上购物的参考.也许这,安装后,它占用的大小:基本长度=28.5cm.深度=19.5cm,高=19.5,因为制造商推荐的约两个天线是 ...

  10. 【SSRS】入门篇(六) -- 分组和总计

    原文:[SSRS]入门篇(六) -- 分组和总计 通过[SSRS]入门篇(五) -- 设置报表格式的设计,一份简单格式的报表已产生,如下图: 这节来说说分组和总计: 根据日期.订单对数据进行分组 添加 ...