MongoDB的where查询
MongoDB的where查询
MongoDB的where查询有时候,键值对的查询方式并不能满足我们的需求,我们有如下一个集合:
> db.foo.find()
{ “_id” : ObjectId(“4e9165cf717ed94f8289ac0c”), “bar” : “baz”, “count” : 35 }
{ “_id” : ObjectId(“4e916661739f1da5452a4dfe”), “bar” : “bazz”, “count” : 3 }
{ “_id” : ObjectId(“4e9165cf717ed94f8289ac0d”), “bar” : “baz”, “count” : 35 }
{ “_id” : ObjectId(“4e928bf8735a86e2c6f848ed”), “apple” : 1, “banana” : 6, “peach” : 3 }
{ “_id” : ObjectId(“4e928c17735a86e2c6f848ee”), “apple” : 1, “spinach” : 4, “watermelon” : 4 }
{ “_id” : ObjectId(“4e928d8a735a86e2c6f848ef”), “bar” : “baz”, “banana” : “baz” }
需要返回有两个字段相同的文档,也就是要返回如下文档
{ “_id” : ObjectId(“4e928c17735a86e2c6f848ee
{ “_id” : ObjectId(“4e928d8a735a86e2c6f848ef
就需要使用”$where“并借助javascript来做了
> db.foo.find({“$where”:function(){
for(var current in this){
for(var other in this){
if(current != other && this[current] == this[other]){
return true;
}
}
}
return false;
}})
如果返回true,文档作为结果的一部分被返回;如果为false,则不会返回。
$where查询有以下几种写法:
> db.foo.find({“$where”:”this.x+this.y==10″})
> db.foo.find({“$where”:”function(){return this.x+this.y==10;}”})
tips:不是非常必要时,一定要避免使用”$where”查询,因为效率太低,相当的。文档在MongoDB中是以BSON格式保存的,在$where查询时,每个文档都要从BSON转换为javascript对象然后再通过”$where”中的表达式来运行。有时可以将常规查询作为前置过滤,再使用”$where”查询对结果进行调优
- mongodb中mapreduce实例
- MongoDB的MapReduce的用法
- MongoDB中的索引的操作
- MongoDB的连接字符串
- mongodb索引的优化
- Mongodb数据导入导出
- MongoDB聚合函数
- mongodb insert操作
- mongodb distinct去重
- mongodb备份和还原
- mongodb简单介绍和安装
- mongodb用户权限
- mongodb基本数据类型
- mongodb常用命令的语法
- mongodb group分组
- mongodb容器化部署映射端口访问(Docker 部署 MongoDB容器的方法)
- 泪目 这位 刷屏 的英雄,是全椒人的骄傲(泪目这位刷屏)
- 人从众 火炎焱 全椒再现 正月十六走太平 的魅力(人从众火炎焱全椒再现)
- 官宣 全椒籍明星许海峰 奚秀兰 方芳 王璐瑶携手回家 走太平(全椒籍明星许海峰)
- 以前全椒人是怎么过冬的 满满都是回忆(以前全椒人是怎么过冬的)
- NVIDIA显卡份额冲上88 A饭发愁 游戏优化恐没A卡份了(NVIDIA显卡份额冲上88A饭发愁)
- AMD YES A卡还是N卡 A卡和N卡的区别(AMDYESA卡还是N卡)
热门推荐
- mysql字段和关键字(mySQL之关键字的执行优先级讲解)
- ftp服务器两种连接方式(FTP服务器 架设考虑三方面的安全因素)
- HTML5中新增的Input类型
- dedecms怎么调用标签(织梦DEDECMS dede:arclist,dede:list获取附加表字段内容的方法)
- python3知识点汇总(Python3几个常见问题的处理方法)
- python如何对参数长度进行限制(python 多个参数不为空校验方法)
- php中变量定义规则(php use和include区别总结)
- css3实现凸起效果(CSS3轻松实现圆角效果)
- pythonjson格式化原理(详解pythonstr与json类型转换)
- js网站前端效果(JS如何让你的移动端交互体验更加优秀)