MongoDB查询之高级操作详解(多条件查询、正则匹配查询等)


本文整理自网络,侵删。

MongoDB查询之高级操作

语法介绍

MongoDB查询文档使用find()方法,同时find()方法以非结构化的方式来显示所有查询到的文档。

-- 1.基本语法
db.collection.find(query, projection) -- 返回所有符合查询条件的文档
db.collection.findOne(query, projection) -- 返回第一个符合查询条件的文档
-- query:可选,查询条件操作符,用于指定查询条件
-- projection:可选,投影操作符,用来指定需要返回的键(默认省略)
-- 例1:查询users集合中年龄为18的所有文档
db.users.find({age: 18})

-- 2.如果需要以易读的方式来观察数据,可以使用pretty()方法
db.collection.find(query, projection).pretty()

AND 条件与 OR 条件

MongoDB的find()方法可以传入多个键,每个键以逗号隔开,这样即可起到SQL的AND条件

-- 1.AND条件基本语法
db.collection.find({key1:value1, key2:value2})
-- 例1:查询users集合中年龄为18的女生的所有文档
db.users.find({age: 18, sex: 'girl'})

-- 2.OR条件基本语法
db.collection.find({
 $or: [
 {key1: value1},
 {key2:value2}
 ]
})
-- 例2:查询users集合中年龄为18或性别为女生的所有文档
db.users.find({
 $or: [
 {age: 18},
 {sex: 'girl'}
 ]
})

条件操作符

条件操作符用处理条件关系以从MongoDB中查询符合条件的文档数据,条件操作符如下:

  • 大于:$gt
  • 小于:$lt
  • 大于等于:$gte
  • 小于等于:$lte
-- 查询users集合中年龄大于18岁的文档数据
db.users.find({age : {$gt : 18}})
-- 查询users集合中年龄小于18岁的文档数据
db.users.find({age : {$lt : 18}})
-- 查询users集合中年龄大于等于18岁的文档数据
db.users.find({age : {$gte : 18}})
-- 查询users集合中年龄大于等于18岁的文档数据
db.users.find({age : {$lte : 18}})

$type操作符

$type操作符是基于BSON类型来检索集合中匹配的数据类型,MongoDB中可以使用查询的数据类型如下表:

阅读剩余部分

相关阅读 >>

mongodb连接和创建数据库的方法讲解

mongodb中对文档的增删查改基本操作方法总结

mongodb常用操作命令大全

mongodb在windows平台的安装及配置方法

mongodb常用数据类型分享

mongodb加入到windows的本地服务项的方法

mongodb教程之聚合(count、distinct和group)

mongodb入门教程之主从复制配置详解

燕十八mongodb视频资料分享

如何备份,还原和迁移mongodb数据库

更多相关阅读请进入《mongodb》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...