Почему некоторые поля не создаются при выполнении миграций?

У меня есть две модели в models.py

class Bid(models.Model):
    bid = models.IntegerField(default = 0)
    user = models.ForeignKey(User, on_delete = models.CASCADE, related_name = "bid")
    def __str__(self):
        return f"Bid of {self.bid} from {self.user}"

class AuctionListings(models.Model):
    name_of_item = models.CharField(max_length=32)    
    description = models.CharField(max_length=400)    
    owner = models.ForeignKey(User, on_delete = models.CASCADE, related_name="auctionlistings", default = None)**    
    bid = models.ForeignKey(Bid, on_delete = models.CASCADE, related_name = "auctionlistings", default = None)**    
    is_closed = models.BooleanField(default=False, blank=True, null=True)
    url = models.CharField(max_length=800)    
    watchlist = models.ManyToManyField(User, blank=True, related_name="watch_listings")    
    category = models.CharField(max_length=50)

Когда я совершаю миграции:

operations = [
        migrations.CreateModel(
            name='AuctionListings',
            fields=[
                ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('name_of_item', models.CharField(max_length=32)),
                ('description', models.CharField(max_length=400)),
                ('is_closed', models.BooleanField(blank=True, default=False, null=True)),
                ('url', models.CharField(max_length=800)),
                ('category', models.CharField(max_length=50)),
            ],
        ),
        migrations.CreateModel(
            name='Bid',
            fields=[
                ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('bid', models.IntegerField(default=0)),
                ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='bid', to=settings.AUTH_USER_MODEL)),
            ],
        ),

Мой вопрос: Почему Django не создал поля: "bid" и "user", указанные в models.py.

Ключом к пониманию этого поведения является метод generate_created_models, используемый, когда Django пытается определить операции, необходимые при генерации миграций. В документации по этому методу мы можем прочитать следующее:

    """
    Find all new models (both managed and unmanaged) and **make create
    operations for them as well as separate operations to create any
    foreign key or M2M relationships (these are optimized later, if
    possible)**.
    Defer any model options that refer to collections of fields that might
    be deferred (e.g. unique_together, index_together).
    """

Поэтому для полей, которые относятся к внешним ключам или отношениям "многие ко многим", Django попытается оптимизировать операции. Наиболее распространенными вариантами являются:

  • Включите поле при создании модели с помощью migrations.CreateModel (как вы видите, в вашем коде есть пример для поля Bid.user).
  • Создайте модель с помощью migrations.CreateModel без поля. После создания Django добавляет каждое новое поле с помощью migrations.AddField (именно это происходит с вашими полями AuctionListings.owner, AuctionListings.bid и AuctionListings.watchlist, которые не были включены при вызове migrations.CreateModel в вашем коде).

Вообще, важно отметить, что поля не создаются. На самом деле, создаются модели, и эти модели содержат поля, которые могут быть указаны при создании или добавлены позже.

Учитывая это, в вашем файле миграций, чуть ниже строк кода, которые вы опубликовали, вы должны увидеть некоторые операции, использующие migrations.AddField и учитывающие добавление полей, которые не включены в migrations.CreateModel.

Вернуться на верх