MongoDB学习3
MongoDB学习(翻译3)
支持的where字句(比较多,今天先写一部分)
本节介绍支持的where字句
正如前面提到的,不是所有的C#表达式都支持where子句。您可以以此文为指导,或者你可以尝试表达,看看它是否工作(如果不支持,抛出运行时异常,)。
Where字句通常使用where查询操作运算符来介绍,但是在某些情况下,我们必须通过&&合并使用它。
注意:
在1.4版本中还有些限制,但是之后的版本已经解除了,所以在此不再翻译。
- && (与操作)
子表达式可以通过&&合并来查询满足所有子表达式的文档

var query =
from c in collection.AsQueryable<C>()
where c.X > 0 && c.Y > 0
select c;
// or
var query =
collection.AsQueryable<C>()
.Where(c => c.X > 0 && c.Y > 0);

上面语句可转化为下述mongodb查询语句
{ X : { $gt : 0 }, Y : { $gt : 0 } } |
在某些情况下我们也可以使用$and操作符,如下面例子:查询c.X被2整除同时被3整除的文档对象:

var query =
from c in collection.AsQueryable<C>()
where (c.X % 2 == 0) && (c.X % 3 == 0)
select c;
// or
var query =
collection.AsQueryable<C>()
.Where(c => (c.X % 2 == 0) && (c.X % 3 == 0));

上面例子可以转化为下面使用了 $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 == 1)
select c;
// or
var query =
collection.AsQueryable<C>()
.Where(c => c.A.Any(a => a.B == 1));

可转化为下面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.测试一个集合中的字段或者属性是否包含一个特定的值:

1. var query = 2. from c in collection.AsQueryable<C>()
3. where c.A.Contains(123)
4. select c;
5. // or 6. var query = 7. collection.AsQueryable<C>()
8. .Where(c => c.A.Contains(123));

可转化为下面mongodb查询语句:
{ A : 123 } |
这个转换依赖于mongodb查询语言对集合项中字段的处理方式
2.测试一个字段或者属性是否包含在一个集合中

var local = new [] { 1, 2, 3 };
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[] { 1, 2, 3 })
select c;
// or
var query =
collection.AsQueryable<C>()
.Where(c => c.A.ContainsAll(new[] { 1, 2, 3 }));

可转化为下面mongodb查询语句:
{ A : { $all : [1, 2, 3] } } |
- ContainsAny (LINQ to MongoDB 扩展方法)
这个方法用于筛选集合中项的字段或者属性是否包含任何一个提供的值:

var query =
from c in collection.AsQueryable<C>()
where c.A.ContainsAny(new[] { 1, 2, 3 })
select c;
// or
var query =
collection.AsQueryable<C>()
.Where(c => c.A.ContainsAny(new[] { 1, 2, 3 }));

可转化为下面mongodb查询语句:
{ A : { $in : [1, 2, 3] } }
- Count 方法 (集合数量、长度)
该方法用于筛选一个可枚举的含有特定数量项的字段或者属性。

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

可转化为下面mongodb查询语句:
{ L : { $size: 3 } } |
- Count 属性 (集合长度)
和方法用法一样,生成同样的查询语句

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

可转化为下面mongodb查询语句::
{ L : { $size: 3 } } |
剩下的待续。。。
MongoDB学习3的更多相关文章
- MongoDB学习笔记系列
回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助 ...
- MongoDB学习笔记—Linux下搭建MongoDB环境
1.MongoDB简单说明 a MongoDB是由C++语言编写的一个基于分布式文件存储的开源数据库系统,它的目的在于为WEB应用提供可扩展的高性能数据存储解决方案. b MongoDB是一个介于关系 ...
- Mongodb学习笔记一(Mongodb环境配置)
Mongodb学习 说明: MongoDB由databases组成,database由collections组成,collection由documents组成,document由fileds组成.Mo ...
- MongoDB学习记录
一.操作符 "$lt" :"<""$lte" :"<=""$gt" :"> ...
- PHP操作MongoDB学习笔记
<?php/*** PHP操作MongoDB学习笔记*///*************************//** 连接MongoDB数据库 **////*************** ...
- MongoDB学习:(二)MongoDB简单使用
MongoDB学习:(二)MongoDB简单使用 MongoDB使用: 执行mongodb的操作之前,我们需要运行命令,来进入操作命令界面 >mongo 提示该错误,说明我们系统缺少一个补丁,该 ...
- MongoDB学习:(一)MongoDB安装
MongoDB学习:(一)MongoDB安装 MongoDB介绍: 直接百科了: MongoDB安装: 1:下载安装: MongoDB安装:https://www.mongodb.com/do ...
- MongoDB学习(四)客户端工具备份数据库
在上一篇MongoDB学习(三)中讲解了如何在服务器端进行数据的导入导出与备份恢复,本篇介绍下如何利用客户端工具来进行远程服务器的数据备份到本地. 以客户端工具MongoVUE为例来进行讲解: 1.首 ...
- mongodb学习(1) 第一次开启 mongdb
1.启动mongdb 可以设置为开机启动 mongod -dbpath=/data/mongodb --fork --port 27017 --logpath=/usr/local/mongodb/l ...
- MongoDB学习之--安全和认证
MongoDB学习之--安全和认证 本文主要介绍两部分内容,Mongodb的安全检查配置以及安全认证操作: 虽然确保系统安全是系统管理员的重要工作,但是作为程序员了解其机制也是大有好处的,毕竟不是每个 ...
随机推荐
- linux_UBUNTU 12.04 上使用 SQUID 架设HTTP正向代理服务器
配置普通HTTP正向代理 安装 1 sudo apt-get install squid squid-common 配置 squid3 1 sudo vim /etc/squid3/squid ...
- HDU 4793 2013 Changsha Regional Collision[简单的平面几何]
圆形奖章给定半径的半径和圆形区域.另一个硬币的半径,然后在桌面上平稳.给定硬币的速(的大小和方向,vx,vy)和坐标(奖牌同心圆形区域,圆和心脏为源),Q币在一个圆形区域和多少下滑(不管是什么圆形区域 ...
- Swift中文教程(三)--流程控制
原文:Swift中文教程(三)--流程控制 Swift用if和switch编写条件控制语句,用for-in,for,while和do-while编写循环.条件控制语句和循环语句中,小括号是可选的,但花 ...
- iOS开发之protocol和delegate
protocol--协议 协议是用来定义对象的属性,行为和用于回调的. 协议中有两个keyword@private和@optional,@private表示使用这个协议必需要写的方法,@op ...
- 拷贝构造函数,深拷贝,大约delete和default相关业务,explicit,给定初始类,构造函数和析构函数,成员函数和内联函数,关于记忆储存,默认参数,静态功能和正常功能,const功能,朋友
1.拷贝构造 //拷贝构造的规则,有两种方式实现初始化. //1.一个是通过在后面:a(x),b(y)的方式实现初始化. //2.另外一种初始化的方式是直接在构造方法里面实现初始化. 案比例如以 ...
- 合并多段zip文件并解压缩
cat xxx.zip.*** >xxx.zip unzip xxx.zip
- PDF.NET SOD Ver 5.1完全开源
PDF.NET SOD Ver 5.1完全开源 前言: 自从我2014年下半年到现在的某电商公司工作后,工作太忙,一直没有写过一篇博客,甚至连14年股票市场的牛市都错过了,现在马上要过年了,而今天又是 ...
- .NET:从 Mono、.NET Core 说起
魅力 .NET:从 Mono..NET Core 说起 前段时间,被问了这样一个问题:.NET 应用程序是怎么运行的? 当时大概愣了好久,好像也没说出个所以然,得到的回复是:这是 .NET 程序员最基 ...
- Android KitCat 4.4.2 ADB 官方所支持的所有Services格式翻译
在之前的文章中有转帖网上同行制作的ADB协议表格<<adb概览及协议参考>>,但不够详尽,所以这里自己另外基于Android 4.4.2的技术文档重新做一次翻译. HOST S ...
- Oracle查字符集查版本号
原文:Oracle查字符集查版本号 ---查字符集 select * from nls_database_parameters ---查版本 查看oracle的版本信息 (1)用客户端连接到数据库,执 ...