SQLite中的文件锁定

| 我正在编写我的第一个SQLAlchemy(0.6.8)/ Python(2.7.1)程序,它位于Windows Vista上运行的SQLite(我认为是3.7.6.3)之上。 为了执行单元测试,我将SQLite指向测试数据库,并且我的单元测试脚本会定期删除数据库文件,因此我一直在使用已知的初始状态进行工作。 有时我的(单线程)单元测试无法删除该文件:
WindowsError: [Error 32] The process cannot access the file because it is being used by another process
使用文件的唯一过程是单元测试工具。显然,我已完成的单元测试之一未释放某些锁定,从而防止了同一过程中的下一个单元测试删除文件。 我已经搜索了创建会话的所有位置,并确认存在相应的session.commit()或session.rollback()。 我已经在我的代码中搜索了所有session.commit()和session.rollback()调用,并在此后立即添加了一个session.close()调用,试图显式释放任何事务锁,但这并没有帮助。 确保在事务结束时删除其余锁以允许删除文件有什么秘密吗?     
已邀请:
有人遇到类似的问题:http://www.mail-archive.com/sqlalchemy@googlegroups.com/msg20724.html 您应该在连接建立时使用NullPool以确保在ѭ1之后没有活动的连接停留
from sqlalchemy import create_engine
from sqlalchemy.pool import NullPool

to_engine = create_engine(\'sqlite:///%s\' % temp_file_name, poolclass=NullPool)
参考:http://www.sqlalchemy.org/docs/06/core/pooling.html?highlight=pool#sqlalchemy.pool 仅在SQLAlchemy 0.7.0之前是必需的。在0.7.0之后,这成为SQLite的默认行为。参考:http://www.sqlalchemy.org/docs/core/pooling.html?highlight=pool#sqlalchemy.pool     
您是否需要在单元测试期间对数据库进行共享访问?如果没有,请对这些测试使用内存中的SQLite数据库。从SQLAlchemy文档中:   如果没有文件路径,则sqlite:memory:标识符是默认的。指定sqlite://,不指定其他任何内容:
# in-memory database
e = create_engine(\'sqlite://\')
无需管理临时文件,无需锁定语义,保证单元测试之间的整洁状态等。     

要回复问题请先登录注册