MongoDB查找条件
1. 关系运算符
$eq 等于
$lt 小于
$lte 小于等于
$gt 大于
$gte 大于等于
$in 在范围内
//查询名字为“小明”和“小刚”的
$condition = [
'name' => ['$in' => ['小明','小刚']]
];
$result = $collection -> find($condition,['_id'=>false]);
2. 逻辑运算符
$and 并且(默认的逻辑关系就是并且)
//查询名年龄大于10并小于30的
$condition = [
'$and' => [
['age' => ['$gt' => 10]],
['age' => ['$lt' => 30]]
]
];
$result = $collection -> find($condition,['_id'=>false]);
$and 简写方式:
//查询名年龄大于10并小于30的
$condition = [
'age' => ['$gt' => 10,'$lt' => 30]
];
$result = $collection -> find($condition,['_id'=>false]);
$or 或者
//查询名年龄等于10或等于30的
$condition = [
'$or' => [
['age' => ['$eq' => 10]],
['age' => ['$eq' => 30]]
]
];
$result = $collection -> find($condition,['_id'=>false]);
$not 非
//查询名年龄不等于10的
$condition = [
'age' => ['$not' => ['$eq' => 10]]
];
$result = $collection -> find($condition,['_id'=>false]);
3. 数组条件
- 当属性的值是数组时,查询需特殊处理
- 查询条件中,属性的值是字符串,表示查找的条件中包含该字符串
//查询hobby里包含swim的
$condition = [
'hobby' => 'swim'
];
$result = $collection -> find($condition,['_id'=>false]);
- 查询条件中,属性的值包含多个内容,使用$all连接
//查询hobby里包含swim和climb的
$condition = [
'hobby' => ['$all' => ['swim','climb']]
];
$result = $collection -> find($condition,['_id'=>false]);
- 查询条件中,属性的值是一个数组,表示严格等于数组的元素
//查询hobby里就是swim和climb的
$condition = [
'hobby' => ['swim','climb']
];
$result = $collection -> find($condition,['_id'=>false]);
4. 内嵌文档
内嵌文档的表现形式类似于属性的值又是一个文档
例如:{
"name":"小明",
"score":{
"Math":100,
"Chinese”:90
}
}
- 通过 . 点号 获得内嵌文档的属性值
//查询数学分数大于80的
$condition = [
'score.math' => ['$gt' => 80]
];
$result = $collection -> find($condition,['_id'=>false]);
5. 正则过滤
使用正则表达式进行过滤
//查询名字以“小”开头的
$condition = [
'name' => new MongoRegex('/^小/')
];
$result = $collection -> find($condition,['_id'=>false]);
6. 排序
注:需要先查询,再对查询的结果进行排序
通过查询结果(cursor游标)的sort方法进行排序,排序有2种方式:
- 1 正序
- -1 倒序
//查询结果
$cursor = $collection -> find([],['_id'=>false]);
//对查询结果倒序排序
$result = $cursor -> sort(['score.math'=>-1]);
foreach($result as $key => $value){
echo ($value['name'].':'.$value['score']['math']).'<br/>';
}
7. 限定数量
对查询的结果进行限定,该方法属于cursor游标的
- skip() 忽略多少
- limit() 保留多少
//查询结果
$cursor = $collection -> find([],['_id'=>false]);
//对查询结果倒序排序,忽略前三个,保留后两个
$result = $cursor
-> sort(['score.math'=>-1])
-> skip(3)
-> limit(2);
foreach($result as $key => $value){
echo ($value['name'].':'.$value['score']['math']).'<br/>';
}
MongoDB查找条件的更多相关文章
- [转]mongodb 查询条件:关系运算符"$lt", "$lte", "$gt", "$gte", "$ne" 逻辑运算符"$and“, "$or“, "$nor“
mongodb 查询条件 这节来说说mongodb条件操作符,"$lt", "$lte", "$gt", "$gte" ...
- MongoDB $type条件操作符
描述 在本章节中,我们将继续讨论MongoDB中条件操作符 $type. $type操作符是基于BSON类型来检索集合中匹配的数据类型,并返回结果. MongoDB 中可以使用的类型如下表所示: 类型 ...
- Informatica 常用组件Lookup之七 查找条件
PowerCenter 使用查找条件来测试收到的值.这与 SQL 查询中的 WHERE 子句相似.为转换配置查找条件时,将对转换输入值和查找源或高速缓存(用查找端口代表)中的值进行比较.当您运行工作流 ...
- mongodb中比较级查询条件:($lt $lte $gt $gte)(大于、小于)、查找条件
查询表中学生年级大于20,如下: db.getCollection('student').find({'age':{'$gt':'20'}}) $lt < (less than ) ...
- 深入理解mongodb查询条件语句
阅读目录 1. 理解:"$lt"."$lte"."$gt" 和 "$gte" 2. 理解 '$ne' 3. 理解 &qu ...
- golang mongodb查找find demo
使用gopkg.in/mgo.v2库操作,插入操作主要使用mongodb中Collection对象的Find方法,函数原型: func (c *Collection) Find(query inter ...
- MongoDB 多条件组合查询
组合条件查询json格式语法 { "$and": [ { "Date": { $gt: ISODate("2015-06-05T00:45:00.00 ...
- mongodb 查询条件
这节来说说mongodb条件操作符,"$lt", "$lte", "$gt", "$gte", "$ne&qu ...
- MongoDB查询条件常用设置
原文地址:http://blog.csdn.net/mcpang/article/details/8731065 Java操作mongodb进行查询,常用筛选条件的设置如下: 条件列表: BasicD ...
随机推荐
- samba 使用tips
安装: 推荐使用新立德包管理器安装 SAMBA配置文件: /etc/samba/smb.conf Samba服务器的启动与关闭: sudo /etc/init.d/smbd start ubuntu访 ...
- 封装一个 TopBarBaseActivity
什么是快速开发嘞,看这个效果 然而我只用了这么几行代码: activity_main.xml 里面什么也没有! 其实说白了哈,就是我把 TopBar 封装在 TopBarBaseActivity 里面 ...
- android开启线程的误区
发现一些刚学android的人,和我当初一样,对android的线程会存在着一定误区. 在android中,开启新线程时,一些人会用以下方法: new Handler().post(r); 但是这样并 ...
- Android资源文件说明
一. Android资源文件简介 1. Android应用资源的作用 (1) Android项目中文件分类 在Android工程中, 文件主要分为下面几类 : 界面布局文件, Java src源文件, ...
- 修改spfile位置
虽然很多地方不建议这么做,可是有HA.oracle软件建在本地盘的情况下,如果spfile放在dbs下,会导致每次修改spfile都要去手动copy到备机上,这是很麻烦的一件事情,所以我把spflie ...
- [IIS | 用户权限] Connect as... 的设置
ApplicationPoolIdentity is actually the best practice to use in IIS7. It is a dynamically created, u ...
- 封装简单的mvc框架
MVC模式(Model-View-Controller)是软件工程中的一种软件架构模式. MVC把软件系统分为三个基本部分:模型(Model).视图(View)和控制器(Controller). PH ...
- 我做SAP CRM One Order redesign的一些心得体会
框架开发和应用程序的开发完全不一样. 举个具体的最近折腾我的例子: 创建新的service order,维护header的shipping data,此时order和shipping data的mod ...
- 3种web会话管理方式
一.基于server端的session管理 在早期web应用中,通常使用服务端session来管理用户的会话.快速了解服务端session: 1) 服务端session是用户第一次访问应用时,服务器就 ...
- jQuery复制table header到表格的最下面
为了让table具有更好的可读性,我们可以将表格的header信息克隆一份到表格的底部,这种特效通过JQuery就很容易实现: 1 2 3 4 5 var $tfoot = $(''); $($('t ...