如何更改 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 本身在每个模型上创建一个主键,自动命名为 id
:https://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
快捷方式 属性 来访问模型中的主键,无论是自动指定还是手动指定。
我有一套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 本身在每个模型上创建一个主键,自动命名为 id
:https://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
快捷方式 属性 来访问模型中的主键,无论是自动指定还是手动指定。