在
Python和SQLite上运行我的单元测试时,我得到了这个熟悉的视线:
SQLite objects created in a thread can only be used in that same thread.
测试运行正常,但错误仍在打印出来.我假设SQLite对象以某种方式泄漏到后台线程.
而不是一块一块地解剖我的代码,有一个简单的方法
>将pdb断点放在某处并查看哪个对象导致违规(从而立即弄清楚它是如何在那里结束的).
>使用错误消息以某种方式打印出对象(以及引用它们的父对象)
最佳答案 到目前为止,通过查看pysqlite的源代码,我可以说不可能只共享连接或游标对象(请参阅pysqlite_check_thread函数用法).
pysqlite_check_thread函数使用该消息引发ProgrammingError异常
SQLite objects created in a thread can only be used in that same thread.
源代码中的某些函数捕获该异常并将其打印出来.
为了在源代码中找到在其他线程中调用连接方法的位置,我建议在连接对象上编写调用包装器,如下所示:
# script name: sqllitethread.py
import inspect
import sqlite3
import threading
import thread
from sqlite3 import ProgrammingError
class CallWrapper(object):
def __init__(self, obj):
self.obj = obj
self.main_thread_id = thread.g