首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Detailview对象关系

Detailview对象关系
EN

Stack Overflow用户
提问于 2017-12-03 20:43:20
回答 1查看 644关注 0票数 1

;TLDR --在发现了一些解决方案之后,我的最后一个问题是,如果有的话,我如何能够访问与主详细视图模型相关的模型?

我试图使用一个通用的细节视图来返回一个对象,它是一个相关的对象。在这个例子中,像麦当劳这样的公司会有任何网站(或地点)。我想要的细节视图能够显示的是公司的细节,以及与公司有关的网站细节。不过我被卡住了。抛开我的努力,不寻求帮助,我没有能够从模型中提取数据参考公司的网站。我哪里出问题了?我已经证明了这一点,在django shell中,使用SiteModel.objects.filter(company=5)显示了所有ID为5的公司名称。

models.py

代码语言:javascript
复制
'''
The company model consists of the base company information 
'''

class CompanyModel(models.Model):
    name = models.CharField(_('Company Name'), max_length=255, blank=False)
    website = models.URLField(_('Company Website'), blank=True)
    since = models.DateField(auto_now_add=True)
    rate = models.DecimalField(max_digits=5, decimal_places=2, blank=False)

    def __str__(self):
        return '%s' % (self.name)

    class Meta:
        ordering = ['name']
        verbose_name = 'Company'
        verbose_name_plural = 'Companies'

'''
The site model consists of sites of a company as
some companies have several sites that we will work from.
'''


class SiteModel(models.Model):
    company = models.ForeignKey(CompanyModel, on_delete=models.PROTECT)
    address = models.ForeignKey(AddressModel, on_delete=models.PROTECT)
    phone = models.ForeignKey(PhoneModel, blank=True, null=True, on_delete=models.PROTECT)
    distance = models.SmallIntegerField(blank=True)

    def __str__(self):
        return '%s - %s, %s' % (self.company, self.address.city, self.address.state)

    class Meta:
        ordering = ['company']
        verbose_name = 'Company Site Information'
        verbose_name_plural = 'Company Sites'

views.py

代码语言:javascript
复制
class CompanyDetailView(DetailView):
    model = CompanyModel
    template_name = 'customers/detail.html'

    def get_context_data(self, **kwargs):
            context = super(CompanyDetailView, self).get_context_data(**kwargs)
            context['sites'] = SiteModel.objects.filter(id=self.kwargs['pk'])
            return context

urls.py

代码语言:javascript
复制
   url(r'^customer/(?P<pk>[0-9a-z-]+)/detail/$', CompanyDetailView.as_view(),
       name='customer-detail'),

更新1:

我的模板显示的是正确的公司,但只有一个网站,并且该网站与公司无关。阿格。它同时显示了ID为5的公司和ID为5的站点。我在这里如何正确地连接这些点?

模板

代码语言:javascript
复制
<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>Customer Detail</title>
  </head>
  <body>
    <div class="container">
      {{ object.name }}
      {% for site in sites %}
        {{ site }}
      {% endfor %}
    </div>
  </body>
</html>

更新2:

我能够通过而不是超级get_context_data来解决这个问题,并且只需要通过相关模型名称的_set后缀进行检查。Django文件参考

模板

代码语言:javascript
复制
  <!DOCTYPE html>
    <html>
      <head>
        <meta charset="utf-8">
        <title>Customer Detail</title>
      </head>
      <body>
        <div class="container">
    {{ company.name }}
    {% for site in company.sites.all %}
      {{ site }}
    {% endfor %}
        </div>
      </body>
    </html>

然而,对此的后续行动是,我如何走不止一层深?继上述模型之后,我也有一个“报告”模型。但是,当我使用与上面相同的方法时,它似乎在第一个模型之后崩溃了。也就是说,我不能只使用company.sites.reports

models.py

代码语言:javascript
复制
class ServiceReportModel(models.Model):
    report_number = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
    site = models.ForeignKey(customers_models.SiteModel, on_delete=models.PROTECT, related_name='reports')
    request_number = models.ForeignKey(ServiceRequestModel,
                                       on_delete=models.PROTECT,
                                       null=True,
                                       blank=True,
                                       related_name='s_report_number'
                                       )
    reported_by = models.ForeignKey(main_models.MyUser, related_name='reports')
    reported_date = models.DateTimeField(auto_now_add=True)
    updated_by = models.ForeignKey(main_models.MyUser, blank=True, null=True, related_name='+')
    updated_date = models.DateTimeField(auto_now=True)
    equipment = models.ForeignKey(customers_models.EquipmentModel, on_delete=models.PROTECT)
    report_reason = models.CharField(max_length=255, null=True)
    time_in = models.DateTimeField(blank=True, null=True)
    time_out = models.DateTimeField(blank=True, null=True)
    actions_taken = models.TextField(null=False, blank=False)
    recommendations = models.TextField(null=True, blank=True)

    def get_absolute_url(self):
        return reverse('service-report', kwargs={'pk': self.pk})

    def __str__(self):
        return '%s - %s, %s' % (self.site.company, self.reported_date.strftime('%d %B %Y'), self.equipment.name)

    class Meta:
        ordering = ['reported_date']
        verbose_name = 'Service Report'
        verbose_name_plural = 'Service Reports'
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-12-04 00:01:31

我得到了一些帮助下的解决方案。我回到了get_context_data方法的超级化,并使用过滤器和双下划线来跟踪关于跨越关系的这份文件

代码语言:javascript
复制
class CompanyDetailView(DetailView):
    model = CompanyModel
    context_object_name = 'company'
    template_name = 'customers/detail.html'

    def get_context_data(self, **kwargs):
            context = super(CompanyDetailView, self).get_context_data(**kwargs)
            context['sites'] = SiteModel.objects.filter(company=self.get_object())
            context['reports'] = ServiceReportModel.objects.filter(site__company=self.get_object())
            return context
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47623088

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档