pythonsqlite3连接池_sqlite - Python sqlite3和并发

sqlite - Python sqlite3和并发

我有一个使用“线程”模块的Python程序。 每隔一秒,我的程序就会启动一个新的线程,从网络中获取一些数据,并将这些数据存储到我的硬盘中。 我想使用sqlite3来存储这些结果,但我无法让它工作。 问题似乎与以下几行有关:

conn = sqlite3.connect("mydatabase.db")

如果我将这行代码放在每个线程中,我会得到一个OperationalError,告诉我数据库文件已被锁定。 我想这意味着另一个线程通过sqlite3连接打开了mydatabase.db并锁定了它。

如果我将这行代码放在主程序中并将连接对象(conn)传递给每个线程,我会得到一个ProgrammingError,说在一个线程中创建的SQLite对象只能在同一个线程中使用。

以前我将所有结果存储在CSV文件中,并且没有任何这些文件锁定问题。 希望这可以用sqlite实现。 有任何想法吗?

RexE asked 2019-05-16T08:15:13Z

14个解决方案

160 votes

与流行的看法相反,较新版本的sqlite3确实支持来自多个线程的访问。

这可以通过可选的关键字参数check_same_thread启用:

sqlite.connect(":memory:", check_same_thread=False)

Jeremiah Rose answered 2019-05-16T08:15:58Z

38 votes

您可以使用消费者 - 生产者模式。 例如,您可以创建线程之间共享的队列。 从Web获取数据的第一个线程将此数据排入共享队列。 另一个拥有数据库连接的线程将队列中的数据从队列中取出并将其传递给数据库。</

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值