Django OneToOneField 结构

发布于 2025-01-09 00:04:32 字数 1517 浏览 0 评论 0原文

我一直在研究和浏览所有文档,但我仍然有点困惑,我想可能是因为有多种方法可以使用 OnToOneField。

我有 4 个模型:赛前、赛中、赛后和比赛。我希望“游戏”包含其他三个模型。

截至目前,它看起来像这样......

    class Pregame(models.Model):
        game_id = models.CharField(max_length=10)
        other fields...

        def __str__(self):
            return str(self.game_id)

    class Ingame(models.Model):
        game_id = models.CharField(max_length=10)
        other fields...

        def __str__(self):
            return str(self.game_id)

    class Postgame(models.Model):
        game_id = models.CharField(max_length=10)
        other fields...

        def __str__(self):
            return str(self.game_id)

    class Game(models.Model):
        game_id = models.CharField(max_length=10)
        pregame = models.OneToOneField(
            Pregame, on_delete=models.CASCADE, null=True)
        ingame = models.OneToOneField(
            Ingame, on_delete=models.CASCADE, null=True)
        postgame = models.OneToOneField(
            Postgame, on_delete=models.CASCADE, null=True)

        def __str__(self):
            return str(self.game_id)

我使用 OnToOne 因为每个游戏只有一个 Pregame、Ingame 和 Postgame,而其他三个模型只属于一个 Game。

我有几个问题我很困惑。

如果其他模型对象之一尚不存在,我是否能够拥有 Game 对象?就像如果有 Pregame 但没有 Ingame 或 Postgame,Game 是否还会存在而只有 Pregame 呢?我看过几个视频,他们做了默认='{}',这是我应该做的吗?

每个模型都有 game_id,这就是我将它们连接到“Game”对象中的方式。是否有像 game_id=game_id 这样的 OneToOneField 选项,以便“游戏”模型会自动将所有模型链接在一起,或者我仍然需要单独进行此操作?

感谢您的帮助和知识。

I have been researching and looking through all the docs but I am still a bit confused, I think maybe because there are multiple ways to use the OnToOneField.

I have 4 models, Pregame, Ingame, Postgame and Game. And I want 'Game' to contain the other three models.

As of right now it looks like this...

    class Pregame(models.Model):
        game_id = models.CharField(max_length=10)
        other fields...

        def __str__(self):
            return str(self.game_id)

    class Ingame(models.Model):
        game_id = models.CharField(max_length=10)
        other fields...

        def __str__(self):
            return str(self.game_id)

    class Postgame(models.Model):
        game_id = models.CharField(max_length=10)
        other fields...

        def __str__(self):
            return str(self.game_id)

    class Game(models.Model):
        game_id = models.CharField(max_length=10)
        pregame = models.OneToOneField(
            Pregame, on_delete=models.CASCADE, null=True)
        ingame = models.OneToOneField(
            Ingame, on_delete=models.CASCADE, null=True)
        postgame = models.OneToOneField(
            Postgame, on_delete=models.CASCADE, null=True)

        def __str__(self):
            return str(self.game_id)

I am using OnToOne because each Game will only have one Pregame, Ingame and Postgame and the other three models will only belong to one Game.

I have a couple questions I am confused about.

Will I be able to have a Game object if one of the other model objects doesn't exist yet? Like if there is a Pregame but no Ingame or Postgame, will Game still exist with just Pregame inside of it? I seen a couple videos where they did a default='{}', is that what I should be doing?

Each model has game_id and that is how I am connecting them all together into the'Game' object. Is there a OneToOneField option like game_id=game_id so the 'Game' model will automatically link all the models together or would I still have to do that separate?

Thank you for your help and knowledge.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

晌融 2025-01-16 00:04:32

首先,您不必在 *game 实体上设置 game_id。您只需添加 related_name

class Game(models.Model):
    game_id = models.CharField(max_length=10)
    pregame = models.OneToOneField(
        Pregame, on_delete=models.CASCADE, null=True, related_name="game")
    ingame = models.OneToOneField(
        Ingame, on_delete=models.CASCADE, null=True, related_name="game")
    postgame = models.OneToOneField(
        Postgame, on_delete=models.CASCADE, null=True, related_name="game")

class Pregame(models.Model):
    other fields...

    def __str__(self):
        return str(self.game_id)

如果其他模型对象之一,我是否能够拥有游戏对象
还不存在?就像有赛前但没有赛中或
赛后,只有赛前的比赛还会存在吗?我看到了
他们在几个视频中设置了默认值='{}',这就是我应该做的
在做什么?

是的,即使没有 *game,Game 对象也可以存在,正如您添加的 null=True 一样。当您的模型不接受 null/空值时,您应该使用默认值。

每个模型都有 game_id,这就是我连接它们的方式
一起进入'Game'对象。是否有像 OneToOneField 这样的选项
game_id=game_id 因此“游戏”模型将自动链接所有游戏
模型一起还是我仍然需要单独进行?

创建此类模型后,您就可以通过 Game 实体进行访问。例如,从赛前赛后

postgame = pregame.game.postgame

First of all, you don't have to set game_id on the *game entities. You can just add related_name:

class Game(models.Model):
    game_id = models.CharField(max_length=10)
    pregame = models.OneToOneField(
        Pregame, on_delete=models.CASCADE, null=True, related_name="game")
    ingame = models.OneToOneField(
        Ingame, on_delete=models.CASCADE, null=True, related_name="game")
    postgame = models.OneToOneField(
        Postgame, on_delete=models.CASCADE, null=True, related_name="game")

class Pregame(models.Model):
    other fields...

    def __str__(self):
        return str(self.game_id)

Will I be able to have a Game object if one of the other model objects
doesn't exist yet? Like if there is a Pregame but no Ingame or
Postgame, will Game still exist with just Pregame inside of it? I seen
a couple videos where they did a default='{}', is that what I should
be doing?

Yes, a Game object can exist even without a *game, as you added null=True. You should use a default when your model does not accept null/empty values.

Each model has game_id and that is how I am connecting them all
together into the'Game' object. Is there a OneToOneField option like
game_id=game_id so the 'Game' model will automatically link all the
models together or would I still have to do that separate?

Once you create such a model, you have access via the Game entity. For example from going to pregame to postgame:

postgame = pregame.game.postgame
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文