尝试在python中定义一个可以搜索给定UUID的函数,如下所示:
def getid(in_id):
return list(CollectionVar.find({"_id":UUID(in_id)}))
并传递一个UUID.我可以像这样从Studio 3T中获取一个我知道存在的UUID:
db.getCollection("CollectionName").find({"_id":UUID("5002aa11-eeb7-4e68-a121-dd51497d2572")})
以上查询恰好返回一个文档. python查询中的同一UUID绝对不返回任何内容.我可以很容易地在其他(非UUID)字段上找到文档,例如,以下代码在较早版本的同一文档上可以正常工作:
def getname(fn,sn):
return list(CollectionVar.find({"Firstname":re.compile(fn, re.IGNORECASE), "Surname":re.compile(sn, re.IGNORECASE)}))
这似乎是uuid.UUID类的问题,而不是pymongo问题?谁能看到这个问题?
PyMongo版本3.6.1
解决方法:
我已经解决了对于遇到此问题的其他人,解决方案如下:
from bson.binary import Binary, UUID_SUBTYPE
def getcust(inid):
newuuid=uuid.UUID(inid).bytes
return list(DealershipConsumer.find({"_id": Binary(bytes(bytearray(newuuid)), UUID_SUBTYPE)}))
UUID_SUBTYPE需要设置为您使用的UUID的任何子类型-在我的情况下是4.