亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Django:模型設計建議

Django:模型設計建議

搖曳的薔薇 2021-09-28 13:20:41
我需要幫助為我的簡單 Django 應用程序創建模型。該應用程序的目的是讓用戶(裁判)注冊比賽,然后管理員將從給定比賽的注冊列表中選擇 2 個用戶(裁判)?,F在我的 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'    )這是我的解決方案,但我不知道它是否以正確的方式完成,所以我想向您尋求幫助。
查看完整描述

1 回答

?
慕田峪9158850

TA貢獻1794條經驗 獲得超7個贊

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


class MatchRegister(models.Model):

    match_id = models.ForeignKey(Match)

    user_id = models.ForeignKey(Users)

    chosen = models.BooleanField(default=False)

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


查看完整回答
反對 回復 2021-09-28
  • 1 回答
  • 0 關注
  • 148 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號