我有一个线程注释系统,它在99.9%的时间里都工作得很好,但偶尔树会坏掉,左/右的值会被复制。
我发现,当两个帖子同时发生时(彼此在一秒之内),就会发生这种情况,并且可能发生的情况是,第二个帖子在第一个帖子完成更新之前更新了树的左/右值。
我来自views.py的评论插入代码如下:
@login_required
@transaction.autocommit
def comment(request, post_id):
parent = get_object_or_404(Post, pk=post_id)
if request.method == 'POST':
form = PostForm(request.POST)
form.parent = post_id
if form.is_valid():
new_post = newPost(request.user, form.cleaned_data['subject'], form.cleaned_data['body'])
new_post.insert_at(parent, 'last-child', save=True)
return HttpResponseRedirect('/posts/')
else:
form = PostForm()
return render_to_response('posts/reply.html', {'requestPost': request.POST, 'form': form, 'parent': parent}, context_instance=RequestContext(request))处理这个问题的正确方法是什么?有没有一种django方法可以确保在第一个数据库事务完成之前不会调用第二个视图?或者我应该在每次插入后重新构建树以确保完整性?或者是否有更好的插入方法可供使用?
谢谢!
编辑:我使用的是MySQL。
发布于 2013-10-28 22:29:31
transaction.autocommit()是一个标准的django行为。如果没有重新定义全局事务行为,则装饰器什么也不做。使用时应使用commit_on_success()装饰器。视图中的所有数据库操作都将在一个事务中。您可以在https://docs.djangoproject.com/en/1.5/topics/db/transactions/上阅读更多信息
PS:在django 1.6中,事务管理将会更新,请注意。
https://stackoverflow.com/questions/19593781
复制相似问题