2014-10-19 105 views
0

嗨我是新的Django,并不知道如何获取多个模型的相关对象。Django获取与多个模型相关

我的代码:

#models.py 
class Candidate(models.Model): 
    user = models.OneToOneField(User, primary_key=True) 
    birth = models.CharField(max_length=50) 
    ... 

class CandidatePhotos(models.Model): 
    user = models.ForeignKey(User) 
    photo = models.ImageField(upload_to='usergallery/%Y/%m/%d') 

class Job(models.Model): 
    candidate = models.ManyToManyField('Candidate', through='CandidateToJob') 
    title = models.CharField(max_length=500) 
    ... 

class CandidateToJob(models.Model): 
    job = models.ForeignKey(Job, related_name='applied_to') 
    candidate = models.ForeignKey(Candidate, related_name='from_user') 
    STATUS_CHOICES = (
     ('1', 'Not approved'), 
     ('2', 'Approved'), 
     ('3', 'Hired') 
    ) 
    status = models.CharField(max_length=2, choices=STATUS_CHOICES) 

在视图我有

#views.py 
class CandidateDetails(generic.DetailView): 
    model = Candidate 
    template_name = 'dashboard/candidate.html' 

    def get_context_data(self, **kwargs): 
     context = super(CandidateDetails, self).get_context_data(**kwargs) 
     context['cand_photos'] = CandidatePhotos.objects.all() 
     return context 

在模板我

<h2>{{ candidate.user.first_name }} {{ candidate.user.last_name }}</h2> 

{% for candidatephotos in cand_photos %} 
    <img alt="" src="{{ candidatephotos.photo.url }}" > 
{% endfor %} 

这里是我的网址仪表板/候选/ PK /。

发生什么是在模板中所有用户的照片被加载,而不是只有我想要的特定用户。 我试图使用{{candidate.user.candidatephotos_set.photo.url}}获取用户照片,但它不起作用。

我也尝试将views.py中的模型从“Candidate”更改为“CandidateToJob”(直通模型),但出现404错误,我不知道为什么。

那么,实现这一目标的最佳做法是什么?

回答

1

根本不需要在视图中查询CandidatePhotos。您的候选对象已通过用户有相关的关系,所以你可以简单地遵循:

{% for photo in object.user.candidatephotos_set.all %} 
+0

嗨丹尼尔,谢谢,但这是行不通的。也许是因为我忘记提及我已经登录为“公司用户”。所以我登录的用户没有照片。在这个应用程序中,我有两种类型的用户:公司用户和候选用户。 – 2014-10-19 15:21:25

+0

对不起,我使用了{%for object.user.candidatephotos_set.all%}中的候选照片。 – 2014-10-19 15:27:15