MongoDB条件操作符

条件操作符用于比较两个表达式并从MongoDB集合中获取数据。MongoDB中条件操作符有:

  • (>) 大于 – $gt
  • (<) 小于 – $lt
  • (>=) 大于等于 – $gte
  • (<=) 小于等于 – $lte
  • (=) 等于 – $eq
  • (!=) 不等于 – $ne

我们使用的数据库名称为 "appblog",集合名称为 "col"

为了方便测试,首先使用以下命令清空集合 "col" 的数据:

db.col.remove({})

插入以下数据

> db.col.insert({
    title: 'PHP', 
    description: 'PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。',
    by: 'APP开发技术博客',
    url: 'http://www.appblog.cn',
    tags: ['php'],
    likes: 200
})
> db.col.insert({title: 'Java', 
    description: 'Java 是由Sun公司于1995年5月推出的高级程序设计语言。',
    by: 'APP开发技术博客',
    url: 'http://www.appblog.cn',
    tags: ['java'],
    likes: 150
})
> db.col.insert({title: 'MongoDB', 
    description: 'MongoDB 是一个 Nosql 数据库',
    by: 'APP开发技术博客',
    url: 'http://www.appblog.cn',
    tags: ['mongodb'],
    likes: 100
})

使用find()命令查看数据:

> db.col.find()
{ "_id" : ObjectId("5aefe63c2d2577acadf1e0d2"), "title" : "PHP", "description" : "PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。", "by" : "APP开发技术博客", "url" : "http://www.appblog.cn", "tags" : [ "php" ], "likes" : 200 }
{ "_id" : ObjectId("5aefe6462d2577acadf1e0d3"), "title" : "Java", "description" : "Java 是由Sun公司于1995年5月推出的高级程序设计语言。", "by" : "APP开发技术博客", "url" : "http://www.appblog.cn", "tags" : [ "java" ], "likes" : 150 }
{ "_id" : ObjectId("5aefe64f2d2577acadf1e0d4"), "title" : "MongoDB", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "APP开发技术博客", "url" : "http://www.appblog.cn", "tags" : [ "mongodb" ], "likes" : 100 }

MongoDB (>) 大于操作符 – $gt

如果你想获取 "col" 集合中 "likes" 大于 100 的数据,你可以使用以下命令:

db.col.find({"likes" : {$gt : 100}})

类似于SQL语句:

select * from col where likes > 100;

输出结果:

> db.col.find({"likes" : {$gt : 100}})
{ "_id" : ObjectId("5aefe63c2d2577acadf1e0d2"), "title" : "PHP", "description" : "PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。", "by" : "APP开发技术博客", "url" : "http://www.appblog.cn", "tags" : [ "php" ], "likes" : 200 }
{ "_id" : ObjectId("5aefe6462d2577acadf1e0d3"), "title" : "Java", "description" : "Java 是由Sun公司于1995年5月推出的高级程序设计语言。", "by" : "APP开发技术博客", "url" : "http://www.appblog.cn", "tags" : [ "java" ], "likes" : 150 }
> 

MongoDB(>=)大于等于操作符 – $gte

如果你想获取 "col" 集合中 "likes" 大于等于 100 的数据,你可以使用以下命令:

db.col.find({likes : {$gte : 150}})

类似于SQL语句:

select * from col where likes >= 150;

输出结果:

> db.col.find({likes : {$gte : 100}})
{ "_id" : ObjectId("5aefe63c2d2577acadf1e0d2"), "title" : "PHP", "description" : "PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。", "by" : "APP开发技术博客", "url" : "http://www.appblog.cn", "tags" : [ "php" ], "likes" : 200 }
{ "_id" : ObjectId("5aefe6462d2577acadf1e0d3"), "title" : "Java", "description" : "Java 是由Sun公司于1995年5月推出的高级程序设计语言。", "by" : "APP开发技术博客", "url" : "http://www.appblog.cn", "tags" : [ "java" ], "likes" : 150 }
> 

MongoDB (<) 小于操作符 – $lt

如果你想获取 "col" 集合中 "likes" 小于 150 的数据,你可以使用以下命令:

db.col.find({likes : {$lt : 150}})

类似于SQL语句:

select * from col where likes < 150;

输出结果:

> db.col.find({likes : {$lt : 150}})
{ "_id" : ObjectId("5aefe64f2d2577acadf1e0d4"), "title" : "MongoDB", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "APP开发技术博客", "url" : "http://www.appblog.cn", "tags" : [ "mongodb" ], "likes" : 100 }
> 

MongoDB (<=) 小于操作符 – $lte

如果你想获取 "col" 集合中 "likes" 小于等于 150 的数据,你可以使用以下命令:

db.col.find({likes : {$lte : 150}})

类似于SQL语句:

select * from col where likes <= 150;

输出结果:

> db.col.find({likes : {$lte : 150}})
{ "_id" : ObjectId("5aefe6462d2577acadf1e0d3"), "title" : "Java", "description" : "Java 是由Sun公司于1995年5月推出的高级程序设计语言。", "by" : "APP开发技术博客", "url" : "http://www.appblog.cn", "tags" : [ "java" ], "likes" : 150 }
{ "_id" : ObjectId("5aefe64f2d2577acadf1e0d4"), "title" : "MongoDB", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "APP开发技术博客", "url" : "http://www.appblog.cn", "tags" : [ "mongodb" ], "likes" : 100 }
> 

MongoDB 使用 (<) 和 (>) 查询 – $lt$gt

如果需要获取 "col" 集合中 "likes" 大于100,小于 200 的数据,可以使用以下命令:

db.col.find({likes : {$lt :200, $gt : 100}})

类似于SQL语句:

select * from col where likes > 100 AND  likes < 200;

输出结果:

> db.col.find({likes : {$lt :200, $gt : 100}})
{ "_id" : ObjectId("5aefe6462d2577acadf1e0d3"), "title" : "Java", "description" : "Java 是由Sun公司于1995年5月推出的高级程序设计语言。", "by" : "APP开发技术博客", "url" : "http://www.appblog.cn", "tags" : [ "java" ], "likes" : 150 }
> 
上一篇 MongoDB查询文档
下一篇 MongoDB $type操作符
目录
文章列表
1 Docker搭建私有仓库
Docker搭建私有仓库
2
Redis 性能测试
Redis 性能测试
3
Java多线程编程四(线程间通信)
Java多线程编程四(线程间通信)
4
Katacoda - 免费学习 Kubernetes 利器
Katacoda - 免费学习 Kubernetes 利器
5
MongoDB后台管理Shell
MongoDB后台管理Shell
最新评论
一位WordPress评论者
一位WordPress评论者
2月12日
您好,这是一条评论。若需要审核、编辑或删除评论,请访问仪表盘的评论界面。评论者头像来自 Gravatar。