Почему некоторые поля не создаются при выполнении миграций?
У меня есть две модели в 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.