为什么 django 不使用“migrate”命令创建数据库表

问题描述 投票:0回答:1

我是 Django 新手,由于某种奇怪的原因,我的模型没有创建数据库表,并且完全不知道为什么。当我运行命令:“python manage.py makemigrations”时,我在控制台输出中显示以下内容:

Migrations for 'auctions':
  auctions/migrations/0001_initial.py
  - Create model User
  - Create model Item

这对我来说似乎是准确的。然后我运行命令:“python manage.py migrate”,控制台输出中显示以下内容。

Operations to perform:
  Apply all migrations: accounts, admin, auctions, auth, contenttypes, sessions
Running migrations:
  No migrations to apply.

查看数据库,果然没有创建任何内容。以下是我的 models.py 文件的输出:

from django.contrib.auth.models import AbstractUser
from django.db import models



class User(AbstractUser):
    def __str__(self):
        return f"{self.first_name}"


class Item(models.Model):
    user = models.ForeignKey(User, on_delete=models.CASCADE, related_name="item_list")
    title = models.CharField(max_length=64)
    description = models.CharField(max_length=256, blank=True)
    img_url = models.CharField(max_length=256, blank=True)
    starting_bid = models.DecimalField(decimal_places=2, max_digits=8)
    category = models.CharField(max_length=24, default='No Category')
    status = models.BooleanField(default=True)

    def __str__(self):
        return f"{self.title}, {self.description}"

这是命令的输出:“python manage.py showmigrations”

Glass-Bids nobility$ python manage.py showmigrations
access
 (no migrations)
accounts
 [X] 0001_initial
admin
 [X] 0001_initial
 [X] 0002_logentry_remove_auto_add
 [X] 0003_logentry_add_action_flag_choices
auctions
 [X] 0001_initial
auth
 [X] 0001_initial
 [X] 0002_alter_permission_name_max_length
 [X] 0003_alter_user_email_max_length
 [X] 0004_alter_user_username_opts
 [X] 0005_alter_user_last_login_null
 [X] 0006_require_contenttypes_0002
 [X] 0007_alter_validators_add_error_messages
 [X] 0008_alter_user_username_max_length
 [X] 0009_alter_user_last_name_max_length
 [X] 0010_alter_group_name_max_length
 [X] 0011_update_proxy_permissions
 [X] 0012_alter_user_first_name_max_length
contenttypes
 [X] 0001_initial
 [X] 0002_remove_content_type_name
sessions
 [X] 0001_initial

python django django-models database-migration django-database
1个回答
7
投票

是的,正如我所想。您可能遵循了某人的建议“删除所有迁移并删除表”,现在

django_migrations
表中仍然有一条记录,显示拍卖应用程序的“0001_initial”已被应用。由于 0001_initial 是在没有迁移的情况下为应用程序一次又一次创建的名称,因此您无法摆脱这种情况。

首先,使用您最喜欢的数据库工具来删除有问题的行:

melvyn=# SELECT app, name FROM django_migrations WHERE name='0001_initial';
     app      |     name     
--------------+--------------
 contenttypes | 0001_initial
 auth         | 0001_initial
 admin        | 0001_initial
 sessions     | 0001_initial
 account      | 0001_initial
 sites        | 0001_initial
 main         | 0001_initial

所以就你而言:

DELETE FROM django_migrations WHERE app='auctions';

现在,如果您运行 migrate,将应用迁移。

下次:如果在没有明确解释的情况下给出此建议,则永远不要删除所有迁移。这是浪费时间,仅在有限的情况下有帮助,而且更经常是问题的原因。

migrate 命令也可以回滚迁移,因此,如果您对任何迁移不满意,请执行以下操作:

% python manage.py migrate auctions zero

(是的,字面意思是

zero
)。这将恢复应用程序的所有迁移。

如果您对最新的更改不满意,请将其调回一位数字。因此,如果一个应用程序有 3 次迁移,请执行以下操作:

% python manage.py migrate auctions 0002

然后您可以丢弃迁移 0003,更改模型并再次运行 makemigrations 并再次迁移。

这样,django 关于应用迁移的假设与您的代码保持同步。

© www.soinside.com 2019 - 2024. All rights reserved.