<p>我和django一起工作</p>
<p>我有一个线程,其目的是获取数据库项的排队列表并修改它们</p>
<p>这是我的模型:</p>
<pre><code>class MyModel(models.Model):
boolean = models.BooleanField(editable=False)
</code></pre>
<p>以及有问题的代码:</p>
<pre><code>def unqueue():
while not queue.empty():
myList = queue.get()
for i in myList:
if not i.boolean:
break
i.boolean = False
i.save() # <== error because database table is locked
queue.task_done()
queue = Queue()
thread = Thread(target=unqueue)
thread.start()
def addToQueue(pk_list): # can be called multiple times simultaneously
list = []
for pk in pk_list:
list.append(MyModel.objects.get(pk=pk))
queue.put(list)
</code></pre>
<p>我现在的代码是失踪的检查等很多。。。我在这里简化了,让它更清楚</p>
<p>在线程中,我可以做些什么来保存到我的数据库中?你知道吗</p>
<p>EDIT:我需要同步,因为I.boolean(以及我实际代码中的其他属性)不能被覆盖</p>
<p>我试图在数据库中创建一个专用表,但没有成功,我仍然有相同的问题</p>
<p>编辑2:我应该明确指出我使用的是SQLite3。我试着看看是否可以在SQLite中解锁/锁定特定的表,似乎锁定只适用于整个db。这可能就是为什么使用专用表没有帮助。你知道吗</p>
<p>这对我来说很糟糕,因为我需要从不同的线程同时访问不同的表,有可能吗?你知道吗</p>
<p>编辑3:看来我的问题就是这里列出的问题
<a href="https://docs.djangoproject.com/en/1.8/ref/databases/#database-is-locked-errors" rel="nofollow">https://docs.djangoproject.com/en/1.8/ref/databases/#database-is-locked-errors</a></p>