如何更改 Django 模型字段的数据类型

How to change the datatype of Django model field

我有一套django模型如下

class FirstCategory(models.Model):
    first_category = models.CharField(max_length=200)
    
    def __str__(self):
        return self.first_category

class SecondCategory(models.Model):
    first_category = models.ForeignKey(FirstCategory, on_delete=models.CASCADE)
    second_category = models.CharField(max_length=200)
    
    def __str__(self):
        return self.second_category
    
class ThirdCategory(models.Model):
    first_category = models.ForeignKey(FirstCategory, on_delete=models.CASCADE)
    second_category = models.ForeignKey(SecondCategory, on_delete=models.CASCADE)
    third_category = models.CharField(max_length=200)
    
    def __str__(self):
        return self.third_category

class FinalList(models.Model):
    unique_number = models.BigIntegerField()
    name = models.CharField(max_length=200)
    
    first_category = models.ForeignKey(FirstCategory, on_delete=models.SET_NULL, null=True, db_column="first_category")
    second_category = models.ForeignKey(SecondCategory, on_delete=models.SET_NULL, null=True, db_column="second_category")
    third_category = models.ForeignKey(ThirdCategory, on_delete=models.SET_NULL, null=True, db_column="third_category")
    
    
    def __str__(self):
        return self.name

当我迁移模型并检查 FinalList table 中字段的数据类型时,我得到以下信息

       column_name         |    data_type
---------------------------+-------------------
 third_category            | bigint
 first_category            | bigint
 second_category           | bigint
 unique_number             | bigint
 name                      | character varying

我已将第一、第二和第三类指定为字符字段。为什么要将其迁移为 BigInt?

我正在尝试在我的表单中实现链式下拉菜单。我正在关注此 SimpleBetterThanComplex 教程

编辑 1:迁移文件的内容

在迁移文件中,我有以下内容

('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),

这不是我自己指定的。我认为 Django 将其创建为自动主字段。这会影响 ForeignKeys 的数据类型吗?

Django 本身在每个模型上创建一个主键,自动命名为 idhttps://docs.djangoproject.com/en/3.2/topics/db/models/#automatic-primary-key-fields

当您创建 ForeignKey 时,Django 会创建一个指向相关模型主键的新字段(在您的例子中是一个自动 ID)。您可以在字段中使用 primary_key=True 参数指定另一个主键。

class FirstCategory(models.Model):
    first_category = models.CharField(max_length=200, primary_key=True)
    
    def __str__(self):
        return self.first_category


此外,Django 提供了 pk 快捷方式 属性 来访问模型中的主键,无论是自动指定还是手动指定。