1

我想以给定的方式显示我的数据库中的数据:

用户

电子邮件集

此刻我有这样的事情:

模型.py

class Person(models.Model):
    name = models.CharField(max_length=50)
    surname = models.CharField(max_length=50)
    objects = PersonManager()

class Email(models.Model):
    person= models.ForeignKey(Person,editable=False,on_delete=models.CASCADE)
    email= models.EmailField()
    objects = EmailManager()

    def __str__(self):
        return self.email

class PersonManager(models.Manager):
    def get_by_natural_key(self,name,surname):
        return self.get(name=name,surname=surname)

在我的views.py中,我覆盖了 get_context_data()方法。

现在,在我的 html 文件中,我有:

{% for user in users %} //person
{% for email in user.email_set.all %}
    {{ user.attr }} 
    {{ email }}   
{% endfor %} 
{% endfor %}  

通过这种方式,订购不是通过用户,而是通过电子邮件,例如:

安装的

用户1

电子邮件 1、电子邮件 2

用户1

电子邮件1

用户1

电子邮件2

4

1 回答 1

1

您必须更改模板代码。使用以下代码:

{% for user in users %} //person
    {{ user.attr }} 
    {% for email in user.email_set.all %}        
        {{ email }}   
    {% endfor %} 
{% endfor %}  
于 2019-06-10T06:14:00.163 回答