我在从mongodb实例获取对象时遇到问题。如果我用pymongo接口搜索这个对象,一切都很好--可以找到对象。如果尝试用pymodm做同样的事情-它会失败并返回错误。
下面是我正在做的事情:
from pymodm import connect, MongoModel, fields
from pymongo import MongoClient
class detection_object(MongoModel):
legacy_id = fields.IntegerField()
client = MongoClient(MONGODB_URI)
db = client[MONGODB_DEFAULT_SCHEME]
collection = db['detection_object']
do = collection.find_one({'legacy_id': 1437424})
print(do)
connect(MONGODB_URI)
do = detection_object.objects.raw({'legacy_id': 1437424}).first()
print(do)第一个打印输出如下:{'_id': ObjectId('5c4099dcffa4fb11494d983d'), 'legacy_id': 1437424}。但是,在执行此命令的过程中:do = detection_object.objects.raw({'legacy_id': 1437424}).first()解释器失败,并显示以下错误:
Traceback (most recent call last):
File "/usr/local/lib/python3.7/site-packages/pymodm/queryset.py", line 127, in first
return next(iter(self.limit(-1)))
StopIteration
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/home/konsof01/PycharmProjects/testthisfuckingshit/settings.py", line 29, in <module>
do = detection_object.objects.raw({'legacy_id': 1437424}).first()
File "/usr/local/lib/python3.7/site-packages/pymodm/queryset.py", line 129, in first
raise self._model.DoesNotExist()
__main__.DoesNotExist这怎么可能呢?我正在尝试使用相同的连接和集合查询完全相同的对象。有什么想法吗?
发布于 2019-04-20 01:10:43
您可以按如下方式进行尝试:
detection_object.objects.raw({'legacy_id': "1437424"} ).first()可能legacy_id被存储为字符串。
否则,请确保db名称出现在MONGO_URI的末尾,因为它在docs中带有下划线。
发布于 2019-05-26 04:54:27
'detection_object‘集合中的每个文档都要求具有'_cls’属性。此属性中存储的字符串值应为
__main__.classname(根据您的代码,类名是detection_object)。
例如,数据库中的文档需要如下所示:
{'_id': ObjectId('5c4099dcffa4fb11494d983d'), 'legacy_id': 1437424, '_cls': '__ main __.detection_object'}https://stackoverflow.com/questions/54239030
复制相似问题