DJANGO-使用简单的历史记录,如何在一个查询中同时显示基本模型记录和相关的历史记录组计算?

时间:2018-08-02 18:16:33

标签: django python-3.x django-simple-history

我正在为我的Django项目使用simple history库。这很漂亮,但是我很难在基本模型对象旁边显示汇总的历史统计信息。 这是我的模型的样子:

from django.db import models
from django.contrib.auth.models import User
from simple_history.models import HistoricalRecords

class RepairForm(models.Model):
    user_id = models.ForeignKey(User, on_delete=models.DO_NOTHING,)
    return_number = models.CharField(max_length=200, unique=True)
    status_id = models.ForeignKey(RFormStatus, on_delete=models.DO_NOTHING)
    ...

    history = HistoricalRecords()

    def __str__(self):
        return self.return_number

Docs使我相信访问历史记录的正确方法是使用历史记录管理器。我可以获得我想要的两组信息:

所有表单(基础模型对象)-

RepairForm.objects.all()

User ID |             Return Number            | Status ID
-----------------------------------------------------------
33      | 0a6e6ef0-a444-4b63-bd93-ae55fe8a3cee | 65001
44      | 5f699795-5119-4dcd-8b94-34f7056e732c | 65002
...

历史计算(历史对象) 在此示例中,我获取每种表单的最新事件-

RepairForm.history.all()\
            .values('return_number').annotate(latest_event_date=Max('history_date'))\
            .order_by('return_number')

          Return Number              | latest_event_date
-----------------------------------------------------------
0a6e6ef0-a444-4b63-bd93-ae55fe8a3cee | 7/27/2018
5f699795-5119-4dcd-8b94-34f7056e732c | 8/1/2018
...

我觉得这应该可以在一个查询中完成,尽管没有?一个查询输出如下内容:

User ID |             Return Number            | Status ID | latest_event_date
------------------------------------------------------------------------------
33      | 0a6e6ef0-a444-4b63-bd93-ae55fe8a3cee | 65001     | 7/27/2018
44      | 5f699795-5119-4dcd-8b94-34f7056e732c | 65002     | 8/1/2018
...

1 个答案:

答案 0 :(得分:0)

您可以添加一个属性(例如“ latest_event_date”)来计算所需结果。然后,当您在RepairForm上运行查询时,总是会计算该属性!

  @property
  def latest_event_date(self):
      ....