MongoDB查找条件
2024-08-27 09:33:47
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/>';
}
最新文章
- ";Couldn&#39;t communicate with a helper application"; in Xcode 7
- 设计模式之 面向对象的养猪厂的故事,C#演示(一)
- Linux磁盘管理之创建磁盘分区05
- webtest 文章
- 转载JQuery 获取设置值,添加元素详解
- 【11】在operator=中处理“自我赋值”
- cf509C Sums of Digits
- Netty之ChannelOption
- 日常踩坑 searter
- 安装wdcp linux一键安装包云系统客户端教程
- mysql日期函数 当前日期 curdate() , 当前年 year(curdate()), 取date的年份 year(date) ,取date的月份 month(date)
- 小tip: 使用CSS将图片转换成黑白(灰色、置灰)
- veu——引入iconfont图标
- BZOJ 1497 最大获利
- git bash的安装与配置
- 【366】通过 python 求解 QP 问题
- Django+Uwsgi+Nginx项目部署文档
- Java——线程死锁问题
- TensorFlow API 汉化
- Git学习笔记二--工作区和暂存区
热门文章
- 9.Java注解(Annotation)
- Django之模型注册
- Asp.net MVC + Signalr 实现多人聊天室
- 【matlab】 QR分解 求矩阵的特征值
- 虚拟机上的Linux Java开发环境部署记录(VirtualBox+Ubuntu)第一章-基础环境搭建
- Web通信协议:OSI、TCP、UDP、Socket、HTTP、HTTPS、TLS、SSL、WebSocket、Stomp
- TFS使用笔记——合并不同分支的代码
- ASP.NET MVC 3 Performance – on par with MVC 2
- HDU1407 测试你是否和LTC水平一样高
- python多进程(一)