0

这是交易,这是我的模型:

class Health_plan(models.Model):
    a = models.IntegerField ()
    b = models.IntegerField ()
    c = models.IntegerField ()

class Doctors_list(models.Model):

    specialty = models.CharField(max_length=15)
    name = models.CharField(max_length=30)
    hp_id = models.ManyToManyField(Health_plan)
    location = models.CharField(max_length=15)

    def __unicode__(self):
        return self.name

所以,我有一个名为 Doctors_list 的表,一个医生有一个专业、一个位置、一个名字和一个涵盖的健康计划列表。

为了解决这个问题,我有一个表格,其中包含列 (a、b、c) 上的健康计划。医生在此列表中由他们的 id 标识,行包含 1 或 0,1 代表健康计划,0 代表未覆盖。像这样:

ID  A B C 
1   0 0 1
2   1 0 0
3   1 0 1 

有没有更好的方法来建立这种关系???

用户首先选择专业,我的表格:

class SpecForm(ModelForm):
    a = Doctors_list.objects.values_list('specialty', flat=True)
    unique = [('---------------','---------------')] + [(i,i) for i in set(a)]
    specialty = forms.ChoiceField(choices=unique)
    class Meta:
        model = Doctors_list

最重要的是:关系专业/健康计划的明智选择。用户选择专业。该专业由一名或多名医生负责。我使用那些医生 ID,然后去检查 health_plan 表,那里有可用的计划。用户选择的计划。

我会继续研究,但欢迎任何提示。

我希望我说清楚了。

4

1 回答 1

1

您所描述的是对多对多关系的滥用。如果您想在 A 和 B 之间创建多对多关系,您所要做的就是在其中一个模型(A 或 B)的定义中添加一个 ManyToMany 字段,然后 django 将负责其余的工作。具体来说,它将创建一个第三个表,它将以 (A.id, B.id) 的形式存储关联。这是此类关系的标准理性数据库过程,Django 正在实现它。

有关多对多关系的一般定义,请参见http://en.wikipedia.org/wiki/Junction_table 。

https://docs.djangoproject.com/en/1.5/ref/models/fields/#manytomanyfield - 用于 Django 实现。

于 2013-05-02T20:50:22.397 回答