pymongo.errors.CursorNotFound: Cursor not found
程序员文章站
2024-02-10 13:56:34
...
在MongoDB操作中,先从数据库中取得所有数据 db.find({}),然后对数据进行for循环
demo = db['demo'].find({})
for cursor in demo:
do_something()
但是当do_something里面的内容耗时过长,在cursor上长时间没有进行操作,会引发cursor在mongodb服务端超时 pymongo.errors.CursorNotFound: Cursor not found 错误。
解决方法
第一种:设置no_cursor_timeout = True,永不超时,游标连接不会主动关闭,需要手动关闭
demo = db['demo'].find({},no_cursor_timeout = True)
for cursor in demo:
do_something()
demo.close() # 关闭游标
第二种 : 设置batch_size返回文档数,默认是20个文档,可以设置小一些,尽量让他能执行完。
demos = db['demo'].find({}).batch_size(1)
for cursor in demo:
do_something()
# 只返回一个文档
注意这两种方法可能也会因为 do_something()里面的操作太过消耗时间,出现超时的错误,所以建议两者一同使用,根据具体情况而定。
推荐阅读
-
python报错:pymongo.errors.CursorNotFound: Cursor not found
-
pymongo.errors.CursorNotFound: cursor id 1598856597812 not found原因以及解决方式
-
python报错:pymongo.errors.CursorNotFound: Cursor not found
-
pymongo.errors.CursorNotFound: Cursor not found, cursor id: 124891571478
-
CSS中控制鼠标指针形状的属性cursor
-
pymongo.errors.CursorNotFound: Cursor not found 错误处理
-
css cursor中鼠标悬停禁用样式
-
pymongo.errors.CursorNotFound: Cursor not found
-
网页鼠标指针样式(cursor属性)
-
[转]Oracle ORA-01403: no data found Exception SYS_REFCURSOR