gpt4 book ai didi

python - PyMongo find_one 不返回现有条目

转载 作者:行者123 更新时间:2023-12-02 05:13:52 25 4
gpt4 key购买 nike

我在使用 Pymongo 的 find_one 函数时遇到了一个奇怪的问题。我在本地计算机上托管了一个名为“cluster_db”的数据库。它有一个名为“集群”的集合。当我在 mongo shell 中运行查询时,我得到以下输出。

> db
cluster_db
> db.clusters.findOne({_id:-8488068664808428000})
{
"_id" : NumberLong("-8488068664808427924"),
"members" : [
{
"participationCoeff" : 1,
"tweetID" : NumberLong("-8488068664808427924")
}
]
}
>

现在,在我的代码初始化阶段,我在模块“dbutil”中定义了一个常量,如下所示:

DB_CONNECTION           = MongoClient('localhost', 27017)
CLUSTER_DB_HANDLE = DB_CONNECTION['cluster_db']

在此之后,在一个函数中,我进行了以下调用。

dbutil.CLUSTER_DB_HANDLE.clusters.find_one({'_id':clusterID})

但是,上面的调用总是返回“无”。如果我转到 MongoShell 并使用相同的 clusterID 运行完全相同的查询,我会看到结果。

我知道这是一个奇怪的错误,但不知何故我无法弄清楚为什么会这样。在其他任何地方,我都能够使用 dbutil.CLUSTER_DB_HANDLE.clusters 成功调用 cluster_db 中的“集群”集合

最佳答案

刚好遇到这个,结果发现我传入的id是int类型,只好调用int(id)进行转换,例如:

db.Employees.find_one({'id' : int(id)}) // this works
db.Employees.find_one({'id' : id}) //this doesn't work

希望这对某人有帮助。

关于python - PyMongo find_one 不返回现有条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14952747/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com