支持的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. javascript权威指南(2)

    JavaScript预定义了一系列全局变量和函数,在自定义变量和函数式要避免使用这些预定义的名称: arguments encodeURI  Infinity  Number  RegExp Arra ...

  2. MVC Bootstrap Helpers

    ASP.NET MVC Bootstrap Helpers   阅读目录 序言 内置的HTML Helpers 创建自定义的Helpers 使用静态方法创建Helpers 使用扩展方法创建Helper ...

  3. HDU 1251 统计拼图 Trie解决问题的方法

    基本上找到一个标准前缀的问题是,只需要insert和search它功能. 这里的主要变化是我n该记录方法,这里n国旗代表的不是叶节点,但是话的标志这条道路后的数字. 然后找到需要找到一个词的前缀,假如 ...

  4. select查询原理

    原文:select查询原理 我并非专业DBA,但做为B/S架构的开发人员,总是离不开数据库,一般开发员只会应用SQL的四条经典语句:select ,insert,delete,update.但是我从来 ...

  5. TDD

    初识TDD 首先说一下名词解释,TDD,英文名称Test-Driven Development,中文名称测试驱动开发,简单的断下句“测试/驱动/开发”,简单的理解一下,就是测试驱动着开发,大白话就是说 ...

  6. POJ 1565 Skew Binary(简单的问题)

    [简要题意]:第二个是数字系统的代表性的定义.而给了你这个号码系统提示的形式和十进制转换之间的关系.现在给你一些这样的系统.让你把它变成2二进制输出. [分析]:当中 base[k]  =  2^(k ...

  7. jQuery随记汇总

    1.jQuery操作行内样式style中的某一项的值:>> <div id="test" style=" display:none;"> ...

  8. XFtp中文乱码解决

    异常处理汇总-开发工具  http://www.cnblogs.com/dunitian/p/4522988.html 一张图解决 异常处理汇总:http://www.cnblogs.com/duni ...

  9. Python系列教程大汇总

    Python初级教程 Python快速教程 (手册) Python基础01 Hello World! Python基础02 基本数据类型 Python基础03 序列 Python基础04 运算 Pyt ...

  10. ORACLE 中极易混淆的几个 NAME 的分析和总结

    我们知道,Oracle中的各种NAME会在我们的各个配置文件里常常出现,大致有下面这些: 在init.ora中有DB_NAME,INSTANCE_NAME,SERVICE_NAME 配置DG的时候,为 ...