在Django 2中,可以通过以下方式避免在重复的文件上保存模型:
首先,你需要在你的Django项目中定义一个模型,例如一个名为MyModel的模型:
from django.db import models
class MyModel(models.Model):
    ...
    # 定义模型的字段
    def save(self, *args, **kwargs):
        # 在保存之前检查文件是否已经存在
        if self.pk is None:  # 如果是新创建的模型
            if MyModel.objects.filter(file=self.file).exists():
                raise ValueError('该文件已经存在')
        else:  # 如果是已存在的模型
            original_file = MyModel.objects.get(pk=self.pk).file
            if original_file != self.file and MyModel.objects.filter(file=self.file).exists():
                raise ValueError('该文件已经存在')
        super().save(*args, **kwargs)
在上述代码中,我们在save()方法中添加了一些逻辑。首先,我们检查模型的主键是否为None,如果是的话,说明这是一个新创建的模型,我们只需检查file字段是否已经存在于数据库中。如果file字段已经存在于数据库中,我们抛出一个ValueError异常。如果模型的主键不为None,说明这是一个已存在的模型,我们需要比较file字段是否与原来的文件相同。如果不同,并且新的file字段已经存在于数据库中,我们也会抛出一个ValueError异常。
注意:在上述代码中,你需要将file字段替换为你实际的文件字段。
这样,当你尝试在重复的文件上保存模型时,会抛出一个异常,从而避免保存重复的文件。