mongodb数据库实现多维数组的模糊查询

最近有一个需求,要查询一个二维数组下面是否含有某个字段

"jichu" : [ 
        [ 
            "商品名称", 
            "罗衣知性保暖毛呢西装外套女2020冬装新款通勤OL深蓝色西服03476 深蓝色 M"
        ], 
        [ 
            "商品品牌", 
            "Roeyshouse"
        ], 
        [ 
            "商品进价", 
            "200"
        ], 
        [ 
            "商品售价", 
            "598"
        ], 
        [ 
            "商品库存", 
            "1200"
        ], 
        [ 
            "商品预警值", 
            "300"
        ], 
        [ 
            "促销活动", 
            "满300减40"
        ]
    ],

例如 : 要查询该数组下面是否含有商品名称为 ’ Roeyshouse ’ 的字段
可以使用 :

var reg = new RegExp(req.query.value)
sql.find(proInfo, { 'jichu': { '$elemMatch': { '$elemMatch': { '$in': [reg] } } }}, { __v: 0 })

如果要进行模糊查询,可以将请求体变成一个正则来匹配
注意: 如果只是查询一个一维数组,那么只要嵌套一次'$elemMatch': { '$in': [reg] }即可

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值