MongoDB(课时13 where条件过滤)
3.4.2.8 条件过滤
关系型数据库开发对于数据的筛选,想到的一定是where语句,MongoDB里面提供的是"$where"。
范例:使用where进行数据的查询
db.students.find({"$where" : "this.age>20"}).pretty()
db.students.find("this.age>20").pretty()
这里的this表示逐条的判断。

对于“$where”是可以简化的,但是这类的操作是属于进行每一行的信息判断,实际上对于数据量较大的情况并不方便。实际上以上的代码严格来讲是属于编写一个操作的函数。
db.students.find(function(){
return this.age > 20;
}).pretty()

db.students.find({"$where" : function(){
return this.age > 20;
}}).pretty()

以上只是查询了一个判断,如果要想实现多个条件的判断,那么就需要使用“and”连接。
db.students.find({"$and" : [
{"$where" : "this.age > 19"},
{"$where" : "this.age < 21"}
]}).pretty()

虽然这种形式的操作可以实现数据查询,但最大缺点是将MongoDB里面保存的BSON数据变为JavaScript的语法结构,这样的方式不方便使用数据库的索引机制。
MongoDB(课时13 where条件过滤)的更多相关文章
- java8 按条件过滤集合
		//黄色部分为过滤条件list.stream().filter(user-> user.getId() > 5 && "1组".equals(user. ... 
- Mysql命令-以NULL做where条件过滤时应该写 IS NULL;
		以NULL做where条件过滤时应该写 IS NULL;SELECT * FROM pet WHERE death IS NULL; SELECT * FROM pet WHERE death IS ... 
- fiddler 按条件过滤
		使用fiddler抓包过程中最希望获取自己想要的数据,不重要的信息最希望的是过滤,如果重要和不重要的数据都展示对我们在寻找资源的时候产生了很大的干扰,所以我们需要按条件过滤: 1.启用fiddler ... 
- automapper如何全局配置map条件过滤null值空值对所有映射起效
		原文 automapper如何全局配置map条件过滤null值空值对所有映射起效 我们在使用automapper的时候经常会遇到这样的问题:假设展示给用户的数据我们用UserDto类,User类就是我 ... 
- 教你用Java web实现多条件过滤功能
		生活中,当你闲暇之余浏览资讯的时候,当你搜索资料但繁杂信息夹杂时候,你就会想,如何更为准确的定位需求信息.今天就为你带来: 分页查询 需求分析:在列表页面中,显示指定条数的数据,通过翻页按钮完成首页/ ... 
- JavaWeb项目之多条件过滤
		相信很多同学在学习java基础之后,面对各种项目还是相当头疼,那今天我将手把手教你学会JavaWeb项目中的多条件过滤,希望你能在与我实战的过程中积累经验,更进一步. 分页查询 需求分析:在列表页面中 ... 
- JAVA 基础编程练习题13 【程序 13 根据条件求数字】
		13 [程序 13 根据条件求数字] 题目:一个整数,它加上 100 后是一个完全平方数,再加上 168 又是一个完全平方数,请问该数是多少? 程序分析:在 10 万以内判断,先将该数加上 100 后 ... 
- Django项目:CRM(客户关系管理系统)--23--15PerfectCRM实现King_admin多条件过滤
		登陆密码设置参考 http://www.cnblogs.com/ujq3/p/8553784.html list_filter = ('source','consultant','consult_co ... 
- js数组Array根据动态条件过滤
		数据 [{ "name": "张三", "score": 153 }, { "name": "李四" ... 
随机推荐
- CentOS6.5安装Twemproxy集群
			Twemproxy,也叫Nutcraker.是一个Twtter开源的一个Redis和Memcache代理服务器. Redis作为一个高效的缓存服务器,非常具有应用价值.但是当使用比较多的时候,就希望可 ... 
- Keepalived+HAproxy实现高可用负载均衡
			总概: Keepalived是一个类似于layer3, 4 & 5交换机制的软件,也就是我们平时说的第3层.第4层和第5层交换.Keepalived的作用是检测web服务器的状态, ... 
- 你真的了解[super ]关键字吗?
			前言 此篇文章是看了阮老师的es6教程,看到super关键字的时候觉得有必要总结梳理一下,原文还是参考 ECMAScript 6入门. 正文 super 这个关键字,既可以当作函数使用,也可以当作对象 ... 
- webpack 3 & React 的配置 。
			今天真是难过的一天 
- VC++文件操作之最全篇
			一.剖析VC中的文件操作 各种关于文件的操作在程序设计中是十分常见,如果能对其各种操作都了如指掌,就可以根据实际情况找到最佳的解决方案,从而在较短的时间内编写出高效的代码,因而熟练的掌握文件操作是十分 ... 
- SQL Server报“GUID应包含带4个短划线的32位数”
			转自:http://www.seayee.net/article/info_106.html 最近在配置一台服务器的MS SQL Server 2005的维护计划自动备份数据库,能创建维护计划,但设置 ... 
- Ignite集群管理——基于静态IP的节点发现
			Ignite作为分布式内存,集群管理必不可少,Ignite支持基于组播,静态IP,Zookeeper,JDBC等方式发现节点,本文主要介绍基于静态IP的节点发现. 两个最重要的TCP通信设置类: 1. ... 
- python实现常量const
			新建const.py: #-*-coding:UTF-8-*- #Filename: const.py # 定义一个常量类实现常量的功能 # # 该类定义了一个方法__setattr()__,和一个异 ... 
- 测试开发-web测试要点
			参数输入考虑 参数数值包含1个.多个.很多个.null.参数值前后包含空格的2种情况 数字类型:正数.负数.0.0.0.+0.0.-0.0.指数.对数.分数.小数.复数.科学计数法的测试,全角的数 ... 
- android 图片大小适配,如何在不同屏幕上适配图片,如何设置可以自适应不同分辨率?
			android 图片大小适配,如何在不同屏幕上适配图片,如何设置可以自适应不同分辨率? Android为了适应不同的分辨率,需要将不同的图片放到不同的drawable目录下,分辨率的匹配规则如下:dr ... 
