No se puede filtrar usando un campo de cadena usando python-eve cuando el valor es _id para otro objeto en mongodb
Pregunta
Estoy experimentando un comportamiento extraño al intentar filtrar una colección usando python-eve, cuando filtro usando el parámetro "dónde" un campo que contiene el _id de otro documento como valor, no se devuelve ningún registro, si agrego una letra adicional/ número después del valor del campo, el registro se devuelve sin problemas, el mismo comportamiento ocurre con cualquier campo que tenga un _id como valor.Como veo en el perfil, parece que el valor se transforma en un $ OID al llamar al DB, pero no estoy seguro de por qué alguna idea.
Gracias Gaston
URL
http://127.0.0.1:5000/contacts?where={"task":"52cdad82a54d7506bc6f9a12"}
Datos devueltos
<resource href="/contacts" title="contacts">
<link rel="parent" href="" title="home"/>
</resource>
Configuración.py
contacts= {
'resource_methods': ['GET', 'POST'],
'schema': {
"timestamp": {
'type': 'datetime',
},
"task": {
'type': 'string'
},
"contact_uuid": {
'type': 'string'
},
"started_by": {
'type': 'string'
},
}
}
Registro MongoDB
{
"_id": {
"$oid": "52cdc33ca54d75085073e7ef"
},
"timestamp": {
"$date": "2014-01-08T21:29:32.603Z"
},
"task": "52cdad82a54d7506bc6f9a12",
"contact_uuid": "43acc81a-bdd2-42dd-bc0f-8279ddd497f4",
"started_by": "admin"
}
Salida del perfil de MongoDB
{
"op": "query",
"ns": "callc.contacts",
"query": {
"task": {
"$oid": "52cdad82a54d7506bc6f9a16"
}
},
"ntoreturn": 10,
"ntoskip": 0,
"nscanned": 9,
"keyUpdates": 0,
"numYield": 0,
"lockStats": {
"timeLockedMicros": {
"r": 172,
"w": 0
},
"timeAcquiringMicros": {
"r": 4,
"w": 4
}
},
"nreturned": 0,
"responseLength": 20,
"millis": 0,
"ts": {
"$date": "2014-01-09T04:04:31.578Z"
},
"client": "XXX.17.153.XXX",
"allUsers": [
{
"user": "xxxxx",
"userSource": "callc"
}
],
"user": "xxxx@callc"
}
Estoy usando una base de datos alojada en mongolab ejecutando mongod 2.4.7
Y virtualenv, con la siguiente salida de "congelación de pip"
- Cerbero==0.4.0
- Eva==0.2
- Eventos==0.2.0
- Matraz==0.10.1
- Matraz-principal==0.4.0
- Frasco-PyMongo==0.3.0
- Cargas de matraces == 0.1.3
- Frasco-WTF==0.9.3
- Jinja2==2.7
- Marcado seguro==0,18
- Formularios WT==1.0.5
- Trabajo ==0.9.4
- intermitente == 1.3
- matraz-mongoengine==0.7.0
- es peligroso==0.22
- mongomotor==0.8.6
- contraseña==1.6.1
- py==1.4.18
- pymongo==2.6.3
- pruebapy==2.4.2
- solicitudes == 2.1.0
- simplejson==3.3.0
- wsgiref==0.1.2
Solución
La última versión de desarrollo es compatible query_objectid_as_string
.Configúrelo en True
para su campo "tarea" y debería estar bien.Ver documentos para detalles.