MongoDB - 查找符合条件的文档
MongoDB - find documents with couple conditions
要求:
计算集合中的所有文档 WHERE
objects.objectType 等于 'group'
和
(objects.objectType 不等于 'person' && 关系等于 'Exposed_to')
预期:将 return 所有文档的计数,其中 objects.objectType 等于 'group' 且不包含 [= 下的任何 (objectType:person && realtion:Exposed_to) 32=]数组.
匹配文档示例:
"objects": [
{
"objectType": "organization",
"relation": "Exposed_to"
},
{
"objectType": "group",
"relation": "Exposed_to"
}
]
不应计算的文档示例:
"objects": [
{
"objectType": "person",
"relation": "Exposed_to"
},
{
"objectType": "group",
"relation": "Exposed_to"
}
]
我试过以下查询:
.count({
'objects.objectType': 'group',
'objects': {
$elemMatch: {
$and: [{'objectType' : {$ne: 'person'}, 'relation': 'Exposed_to'}]
}
}})
但它似乎无法正常工作。
我不确定在这种情况下是否应该使用聚合 - 我在这方面的知识也较少。
我很乐意得到一些帮助。谢谢!
它对你有用吗? https://mongoplayground.net/p/Q-dj7_O_AJR
这个 playground 不支持 count
,所以我用 find
代替
db.collection.find({
$and: [
{
"objects.objectType": "group"
},
{
objects: {
$not: {
"$elemMatch": {
"objectType": "person",
"relation": "Exposed_to"
}
}
}
}
]
})
要求: 计算集合中的所有文档 WHERE objects.objectType 等于 'group' 和 (objects.objectType 不等于 'person' && 关系等于 'Exposed_to')
预期:将 return 所有文档的计数,其中 objects.objectType 等于 'group' 且不包含 [= 下的任何 (objectType:person && realtion:Exposed_to) 32=]数组.
匹配文档示例:
"objects": [
{
"objectType": "organization",
"relation": "Exposed_to"
},
{
"objectType": "group",
"relation": "Exposed_to"
}
]
不应计算的文档示例:
"objects": [
{
"objectType": "person",
"relation": "Exposed_to"
},
{
"objectType": "group",
"relation": "Exposed_to"
}
]
我试过以下查询:
.count({
'objects.objectType': 'group',
'objects': {
$elemMatch: {
$and: [{'objectType' : {$ne: 'person'}, 'relation': 'Exposed_to'}]
}
}})
但它似乎无法正常工作。 我不确定在这种情况下是否应该使用聚合 - 我在这方面的知识也较少。
我很乐意得到一些帮助。谢谢!
它对你有用吗? https://mongoplayground.net/p/Q-dj7_O_AJR
这个 playground 不支持 count
,所以我用 find
db.collection.find({
$and: [
{
"objects.objectType": "group"
},
{
objects: {
$not: {
"$elemMatch": {
"objectType": "person",
"relation": "Exposed_to"
}
}
}
}
]
})