概述
class MyModel: email = models.EmailField(unique=True) def save(self): .... # save model def clean(self): .... # validate model,make sure email doesn't already exist.
通常,如果浏览器提交的表单中包含已存在的值的电子邮件,则会因模型表单字段验证而引发ValidationError.
如果两个浏览器同时提交相同的电子邮件,而电子邮件是一个尚不存在的值,则至少有一个请求会通过将一行保存到数据库中而成功.另一个请求,如果它在第一个请求之后到达足够长的时间,将被正常处理 – 引发ValidationError表示该电子邮件已经存在.但是如果它几乎与第一个同时到达,则clean()将成功 – 电子邮件尚不存在,但是当执行save()方法时,第一个请求中的行将具有得救了在后一种情况下,将引发IntegrityError,服务器将返回Internal Server 500错误,这是不合需要的.
如何防止这最后一种情况?数据库交易?
如果您使用Postgresql,这是一个完美的例子:
http://www.caktusgroup.com/blog/2009/05/26/explicit-table-locking-with-postgresql-and-django/
如果您在某个其他数据库下,则必须调查如何执行表锁定.
总结
以上是编程之家为你收集整理的python – Django在clean()和save()之间锁定全部内容,希望文章能够帮你解决python – Django在clean()和save()之间锁定所遇到的程序开发问题。
如果您也喜欢它,动动您的小指点个赞吧