Django rest_framework ошибка MultipleObjectsReturned метод get возвращает более одного объекта
Я делаю проект, в котором каждый раз, когда кто-то создает элемент, в ClearingOffice он будет увеличивать office_serial +1,
но он говорит get() returned more than one ClearingOffice -- it returned 14!
и когда я пытаюсь фильтровать, он увеличивает все office_serials
models.py
class CustomUser(AbstractBaseUser, PermissionsMixin):
email = models.EmailField(_('email address'), unique=True)
is_staff = models.BooleanField(default=False)
is_active = models.BooleanField(default=True)
date_joined = models.DateTimeField(default=timezone.now)
userid = models.CharField(null=True, max_length=9)
office = models.ForeignKey('ClearingOffice', models.DO_NOTHING, blank=True, null=True)
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = []
objects = CustomUserManager()
def __str__(self):
return self.email
class ClearanceItem(models.Model):
cl_itemid = models.CharField(primary_key=True, max_length=20, default=get_default_id)
studid = models.CharField(max_length=9, blank=True, null=True)
office = models.ForeignKey('ClearingOffice', models.DO_NOTHING, blank=True, null=True)
class Meta:
managed = False
db_table = 'clearance_item'
class ClearingOffice(models.Model):
# this should be office_id
office = models.OneToOneField('Office', models.DO_NOTHING, primary_key=True)
staff = models.TextField(blank=True, null=True)
office_serial = models.IntegerField(blank=True, null=True)
class Meta:
managed = False
db_table = 'clearing_office'
signals.py
@receiver(post_save, sender=ClearanceItem)
def create_transaction_log(sender, instance, created, **kwargs):
if created:
TransactionLog.objects.create(cl_itemid=ClearanceItem.objects.get(cl_itemid=instance.cl_itemid),
trans_desc="Add Clearance Item",
trans_recorded=str(datetime.now().strftime('%Y-%m-%d')))
ClearingOffice.objects.get(office_serial=instance.office.office_serial).update(office_serial=F('office_serial') + 1)
Странно то, что у меня есть два пользователя, один из которых работает, увеличивая свой office_serial, а другой увеличивает их все
кто-нибудь может объяснить, почему это происходит?
Edit: Я добавил serializer.py
class ClearanceItemSerialize(serializers.ModelSerializer):
class Meta:
model = ClearanceItem
fields = '__all__'
def create(self, validated_data):
validated_data["office"] = self.context["request"].user.office
validated_data["recorded_by"] = self.context["request"].user.userid
validated_data["cl_itemid"] = self.context["request"].user.office.office_id + validated_data.get('sy') + validated_data.get('sem') + '-' + str(self.context["request"].user.office.office_serial)
return super().create(validated_data)
Вы можете использовать id, он будет выполнять ту же цель, которую вы хотите. Он присваивается всем созданным пользователям и увеличивается на 1 для каждого созданного пользователя. В вашем случае office_serial вызывается для всех экземпляров, созданных в соответствии с запросом, и будет обновлен соответствующим образом.