【发布时间】:2015-05-25 18:23:36
【问题描述】:
我正在尝试查找 tipo=CD 和 canciones 不包含具有 title=Pajaritos 和 cancion=2 的子文档的所有文档
这是我喜欢在canciones字段中实现的:
not (title=Pajaritos and cancion=2)
我有以下收藏:
{
"tipo": "CD",
"Artista":"Los piratas",
"Titulo": "Recuerdos",
"canciones": [
{
"cancion":1,
"titulo":"Adios mi barco",
"longitud": "3:20"
},
{
"cancion":2,
"titulo":"Pajaritos",
"longitud": "4:15"
}
]
},
{
"tipo": "CD",
"Artista":"Los piratas",
"Titulo": "Recuerdos",
"canciones": [
{
"cancion":1,
"titulo":"Adios mi barco",
"longitud": "3:20"
},
{
"cancion":3,
"titulo":"Pajaritos",
"longitud": "4:15"
}
]
},
{
"tipo": "CD",
"Artista":"Los piratas",
"Titulo": "Recuerdos",
"canciones": [
{
"cancion":1,
"titulo":"Adios mi barco",
"longitud": "3:20"
},
{
"cancion":3,
"titulo":"Pajaritos",
"longitud": "4:15"
},
{
"cancion":4,
"titulo":"Pajaritos4",
"longitud": "44:15"
}
}
我的查询
db.media.find({"tipo" : "CD" ,"canciones" : { "$ne" : {"$elemMatch" : {"titulo" : "Pajaritos", "cancion" : 2}}}})
我不想要的结果
{ "_id" : ObjectId("550f0a1c009ed3a1c9bbcdc1"), "tipo" : "CD", "Artista" : "Los piratas", "Titulo" : "Recuerdos", "canciones" : [ { "cancion" : 1, "titulo" : "Adios mi barco", "longitud" : "3:20" }, { "cancion" : 2, "titulo" : "Pajaritos", "longitud" : "4:15" } ] }
{ "_id" : ObjectId("550f0a1c009ed3a1c9bbcdc2"), "tipo" : "CD", "Artista" : "Los piratas", "Titulo" : "Recuerdos", "canciones" : [ { "cancion" : 1, "titulo" : "Adios mi barco", "longitud" : "3:20" }, { "cancion" : 3, "titulo" : "Pajaritos", "longitud" : "4:15" } ] }
{ "_id" : ObjectId("550f0a1c009ed3a1c9bbcdc3"), "tipo" : "CD", "Artista" : "Los piratas", "Titulo" : "Recuerdos", "canciones" : [ { "cancion" : 1, "titulo" : "Adios mi barco", "longitud" : "3:20" }, { "cancion" : 3, "titulo" : "Pajaritos", "longitud" : "4:15" }, { "cancion" : 4, "titulo" : "Pajaritos4", "longitud" : "44:15" } ] }
如您所见,结果包含试图避免的"titulo" : "Pajaritos"。
尝试使用$not 运算符而不是$ne
{ "_id" : ObjectId("550f173fc357b7a4e7a46e10"), "tipo" : "CD", "Artista" : "Los piratas", "Titulo" : "Recuerdos", "canciones" : [ { "cancion" : 1, "titulo" : "Adios mi barco", "longitud" : "3:20" }, { "cancion" : 3, "titulo" : "Pajaritos", "longitud" : "4:15" } ] }
{ "_id" : ObjectId("550f173fc357b7a4e7a46e11"), "tipo" : "CD", "Artista" : "Los piratas", "Titulo" : "Recuerdos", "canciones" : [ { "cancion" : 1, "titulo" : "Adios mi barco", "longitud" : "3:20" }, { "cancion" : 3, "titulo" : "Pajaritos", "longitud" : "4:15" }, { "cancion" : 4, "titulo" : "Pajaritos4", "longitud" : "44:15" } ] }
【问题讨论】:
-
您只想要
canciones中与给定条件或文档匹配的子文档吗? -
@Michael 我想要这份文件。
标签: mongodb mongodb-query