MongoDB 的使用总结 判断数组非空的几种方式

mongodb中判断数组非空的几种方式

数组属性的非空包括:属性不存在 属性值为null 属性为空数组

// 构造测试数据
db.col00.insertMany([
	{"name": "array不存在"},
	{"name": "array是空", "array": null},
	{"name": "array是空数组", "array": []},
	{"name": "array是正常数组", "array": ["1","2"]}
])

// $elemMatch 与 $ne组合查询
db.col00.find({
    "array": {
        "$elemMatch": {
            "$ne": null
        }
    }
})

// $and $ne 组合查询
db.col00.find({
    "$and": [{
        "array": {
            "$ne": []
        }
    }, {
        "array": {
            "$ne": null
        }
    }]
})

// $ne 与 $where 组合查询
db.col00.find({
    "array": {"$ne": null},
    "$where": "this.array.length > 0"
})

// $ne 与 $not $size 组合查询
db.col00.find({
    "array": {
        "$ne": null,
        "$not": {
            "$size": 0
        }
    }
})

// $gt 查询
db.col00.find({
    "array": {
        "$gt": []
    }
})

// .0 与 $exists组合查询
db.col00.find({
    "array.0": {
        "$exists": true
    }
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值