MongoDB聚合运算符:$eq

文章目录

$eq聚合运算符用于比较两个值并返回是否相等,如果相等返回true,否则返回false

语法

js 复制代码
{ $eq: [ <expression1>, <expression2> ] }

$eq可以用来比较任何类型的值,针对不同的类型使用特定的BSON比较顺序。

举例

inventory集合有下列文档:

json 复制代码
{ "_id" : 1, "item" : "abc1", "description": "product 1", "qty": 300 }
{ "_id" : 2, "item" : "abc2", "description": "product 2", "qty": 200 }
{ "_id" : 3, "item" : "xyz1", "description": "product 3", "qty": 250 }
{ "_id" : 4, "item" : "VWZ1", "description": "product 4", "qty": 300 }
{ "_id" : 5, "item" : "VWZ2", "description": "product 5", "qty": 180 }

下面的聚合操作使用$eq运算符来判断qty是否等于250

js 复制代码
db.inventory.aggregate(
   [
     {
       $project:
          {
            item: 1,
            qty: 1,
            qtyEq250: { $eq: [ "$qty", 250 ] },
            _id: 0
          }
     }
   ]
)

操作返回下面的结果:

json 复制代码
{ "item" : "abc1", "qty" : 300, "qtyEq250" : false }
{ "item" : "abc2", "qty" : 200, "qtyEq250" : false }
{ "item" : "xyz1", "qty" : 250, "qtyEq250" : true }
{ "item" : "VWZ1", "qty" : 300, "qtyEq250" : false }
{ "item" : "VWZ2", "qty" : 180, "qtyEq250" : false }
相关推荐
我是大猴子3 分钟前
解决并发的两种方法(没用到redis)(对上一期的补充)以及开启多个定时任务
数据库·redis·缓存
難釋懷8 分钟前
Redis分片集群散列插槽
数据库·redis·缓存
2501_911088238 分钟前
Web开发与API
jvm·数据库·python
2501_911088239 分钟前
使用Python自动收发邮件
jvm·数据库·python
极客on之路12 分钟前
分库分表(四)
数据库
zklgin15 分钟前
【MySQL】深度学习数据库开发技术:使用CC++语言访问数据库
数据库·mysql·数据库开发
2401_8898846620 分钟前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
李宥小哥24 分钟前
SQLite04-表数据管理
java·jvm·数据库
Smoothcloud_润云37 分钟前
GORM 事务管理与 Repository 模式完整指南
前端·数据库·代码规范
aq553560039 分钟前
SQL 注入漏洞原理以及修复方法
网络·数据库·sql