gpt4 book ai didi

python - Django OneToOneField 和 ForeignKeyField 为字段添加 "_id"后缀

转载 作者:太空宇宙 更新时间:2023-11-04 07:07:13 26 4
gpt4 key购买 nike

当我查看由 Django 创建的 group_cover 表时,有 group_id_id 字段和 group_cover 字段。我想将 group_id_id 更改为 group_id

模型.py

class Group(models.Model):

group_id = models.AutoField(primary_key=True)
group_name = models.CharField(max_length=50, unique=False, blank=False)


class Group_Cover(models.Model):

group_id = models.OneToOneField(Group, primary_key=True) # this create group_id_id
group_cover = models.ImageField(upload_to="/image/group/")


class Group_Member(models.Model):

user_id = models.ForeignKey(User2) # this create user_id_id
group_id = models.ForeignKey(Group) # this create group_id_id

是的,如果我写,

group = models.OneToOneField(Group, primary_key=True)

它可能有效,但我可能不需要在某些字段上使用“_id”后缀。

我读了this document ,但由于我的英语不好,我看不懂路。你能教我怎么改吗?

最佳答案

Django 向自动生成的主键添加一个 _id 后缀。除非使用遗留数据库,否则您通常不需要担心它们。

解决方案 2 是我推荐用于新项目的解决方案。遗留数据库的解决方案 1。

解决方案一

要修改现有代码,请使用以下 db_column 属性,因为它允许您命名数据库中的字段。:

group = models.AutoField(primary_key=True, db_column='group_id')

Documentation

方案二

为了以更“Django”的方式获得相同的结果,让 Django 自动生成主键,然后在 OneToOne 和外键字段中引用模型,如下所示。

class Group(models.Model):
group_name = models.CharField(max_length=50, unique=False, blank=False)

class Group_Cover(models.Model):
group = models.OneToOneField(Group)
group_cover = models.ImageField(upload_to="/image/group/")

class Group_Member(models.Model):
user = models.ForeignKey(User2)
group = models.ForeignKey(Group)

关于python - Django OneToOneField 和 ForeignKeyField 为字段添加 "_id"后缀,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36173123/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com