假设我有一个Basket模型,并且想验证是否5 Item可以添加s个以上的代码:
Basket
5
Item
class Basket(models.Model): items = models.ManyToManyField('Item') def save(self, *args, **kwargs): self.full_clean() super(Basket, self).save(*args, **kwargs) def clean(self): super(Basket, self).clean() if self.items.count() > 5: raise ValidationError('This basket can\'t have so many items')
但是,试图保存时,Basket一个RuntimeError因为超过最大递归深度被抛出。
RuntimeError
错误如下:
ValueError: "<Basket: Basket>" needs to have a value for field "basket" before this many-to-many relationship can be used.
它发生if self.items.count() > 5:在行中。
if self.items.count() > 5:
显然,在保存模型时,Django的复杂性根本不允许您验证m2m关系。那我该如何验证它们呢?
您 永远无法 使用模型的干净方法来验证关系。这是因为在清理时间,该模型可能不存在,就像您的购物篮一样。不存在的东西,也可能没有关系。
您要么需要对@bhattravii指出的表单数据进行验证,要么调用form.save(commit=False)并实现一个称为的方法save_m2m来实现限制。
form.save(commit=False)
save_m2m
要在模型级别强制执行限制,您需要收听m2m_changed信号。请注意,向最终用户提供反馈要困难得多,但这确实可以防止通过其他方式将篮子过度装满。
m2m_changed