簡體   English   中英

Django:模型設計建議

[英]Django: Suggestion for models design

我需要幫助為我的簡單 Django 應用程序創建模型。

該應用程序的目的是讓用戶(裁判)注冊比賽,然后管理員將從給定比賽的注冊列表中選擇 2 個用戶(裁判)。 現在我的 Matches 模型如下所示:

class Match(models.Model):

    match_number = models.CharField(
        max_length=10
    )
    home_team = models.ForeignKey(
        Team,
        on_delete=models.SET_NULL,
        null=True,
        related_name='home_team'
    )
    away_team = models.ForeignKey(
        Team,
        on_delete=models.SET_NULL,
        null=True,
        related_name='away_team'
    )
    match_category = models.ForeignKey(
        MatchCategory,
        on_delete=models.SET_NULL,
        null=True
    )
    date_time = models.DateTimeField(
        default=timezone.now
    )
    notes = models.TextField(
        max_length=1000,
        blank=True
    )

我想做的是創建名為 MatchRegister 的新模型,我將在其中保存 match_id 和 user_id,如下所示:

class MatchRegister(models.Model):
    match_id = models.ForeignKey(
        Match
    )
    user_id = models.ForeignKey(
        Users
    )

並且管理員將擁有給定比賽的注冊用戶列表,他將從中選擇兩個,所以我想像這樣修改我的比賽模型(添加兩個新字段):

class Match(models.Model):

    match_number = models.CharField(
        max_length=10
    )
    home_team = models.ForeignKey(
        Team,
        on_delete=models.SET_NULL,
        null=True,
        related_name='home_team'
    )
    away_team = models.ForeignKey(
        Team,
        on_delete=models.SET_NULL,
        null=True,
        related_name='away_team'
    )
    match_category = models.ForeignKey(
        MatchCategory,
        on_delete=models.SET_NULL,
        null=True
    )
    date_time = models.DateTimeField(
        default=timezone.now
    )
    notes = models.TextField(
        max_length=1000,
        blank=True
    )
    ref_a = models.ForeignKey(
        Users,
        on_delete=models.SET_NULL,
        null=True,
        related_name='ref_a'
    )

    ref_b = models.ForeignKey(
        Users,
        on_delete=models.SET_NULL,
        null=True,
        related_name='ref_b'
    )

這是我的解決方案,但我不知道它是否以正確的方式完成,所以我想向您尋求幫助。

如果您確定比賽只會有兩個裁判,那么您提出的建議就可以了。 但是,如果將來有機會更改數字(只有一個,或者可能是三個),另一種方法是向中間表添加一個標志:

class MatchRegister(models.Model):
    match_id = models.ForeignKey(Match)
    user_id = models.ForeignKey(Users)
    chosen = models.BooleanField(default=False)

您需要業務邏輯來將“選擇”引用的數量限制為您預期的數量。 此選項可以輕松增加或減少 ref 的數量,而無需添加或刪除列(只需更改業務邏輯)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM