Opened 8 years ago

Last modified 8 years ago

#27933 closed Bug

FieldDoesNotExist if remove foreign key and remove unique constraint at the same time — at Initial Version

Reported by: Jindi Wu Owned by: nobody
Component: Migrations Version: 1.10
Severity: Normal Keywords:
Cc: Triage Stage: Unreviewed
Has patch: no Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: no UI/UX: no

Description

Remove foreign key b and unique_togetehr constraint from model like following:

class A(models.Model):
    name = models.CharField(max_length=10)
    b = models.ForeignKey('B')

    class Meta:
        unique_together = (('b','name'),)

class B(models.Model):
    text = models.CharField(max_length=10)

-->

class A(models.Model):
    name = models.CharField(max_length=10)

    class Meta:
        unique_together = (('name'),)

class B(models.Model):
    text = models.CharField(max_length=10)

Such error will be thrown.

raise FieldDoesNotExist('%s has no field named %r' % (self.object_name, field_name))
django.core.exceptions.FieldDoesNotExist: A has no field named 'b'

However if swap the order of generated two operations within the migration AlterUniqueTogether and RemoveField, it'll work.

Is this a bug or am I using Django the wrong way?

Change History (1)

by Jindi Wu, 8 years ago

Attachment: bug.zip added
Note: See TracTickets for help on using tickets.
Back to Top