mongodb中使用$in和$all的区别

在这里我启用本地的mongodb进行测试
1:先启动本地的mongodb的服务文件
在这里插入图片描述
2:再启动本地的mongodb

在这里插入图片描述
3:在这里我们使用nosql booster可视化工具进行操作

测试数据为:
在这里插入图片描述

需求1:
查询出包含1或者包含4的数据
db.user.find({ id : { $in : [“1”,“4”] } } );
查询得到:
在这里插入图片描述

需求2:
查询出同时包含4和5的数据,这时就不能使用 i n 来 进 行 查 询 了 , 因 为 i n 只 能 查 询 单 值 , 但 在 m o n g o d b 中 还 存 在 in来进行查询了,因为in只能查询单值, 但在mongodb中还存在 ininmongodball操作符,用于查询整个
db.user.find( { id: { $all:[“4”,“5”] } } )
得到结果:
在这里插入图片描述

但如果我们要查询多个或关系的多值怎么办呢
mongodb还存在一个$or操作符,用户操作或关系

db.user.find(
    {   $or:
    [
        {id:{$all:["1","2"]},},
        {id:{$all:["4","5"]},}
    ]   
    }
    )

得到结果:
在这里插入图片描述

如果查询且关系怎么做呢?
在mongodb中还有一个$and操作符,道理和以上的相同,在这里就不多做描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值