django-tables2自定义列

时间:2016-05-27 13:03:32

标签: python django django-tables2

我现在在我的第一个Django项目上工作。我想渲染结果表,其中包含 Priekabos 模型中的所有字段和 Grafikas 中的一个自定义列,其中应包含类似于 SELECT max(kada_moketi)FROM grafikas WHERE的内容priekabos_id =?。无论我从例子中尝试什么都没有用。我应该用自定义查询编写另一个视图函数(Grafikas.objects.filter(priekabos_id = 1)既没有.aggregate(Max('kada_moketi')也没有.latest('kada_moketi')为我工作)并创建了一个新的表类tables.py后来PriekabosTable会继承吗?这对我来说也不起作用。

这是我的代码:

models.py

class Grafikas(models.Model):
    id = models.AutoField(primary_key=True)
    mokejimo_nr = models.IntegerField()
    kada_moketi = models.DateField()
    priekabos = models.ForeignKey('Priekabos', models.DO_NOTHING)

class Priekabos(models.Model):
    id = models.AutoField(primary_key=True)
    sutarties_nr = models.CharField(unique=True, max_length=45, verbose_name='Sut. Nr.')
    nuomos_pradz = models.DateField()
    sutarties_trukme = models.IntegerField()

views.py

def priekabos_table(request):
    table = PriekabosTable(Priekabos.objects.all())
    RequestConfig(request, paginate={'per_page': 20}).configure(table)
    return render(request, 'isperkamoji_nuoma/priekabos_table.html', {'table': table})

tables.py

class PriekabosTable(tables.Table):
    class Meta:
        model = Priekabos
        attrs = {"class": "paleblue"}
        fields = ('id', 'sutarties_nr', 'nuomos_pradz')

为了更好地理解,这里是'grafikas'表: MySQL 'grafikas' table

1 个答案:

答案 0 :(得分:1)

听起来您可以使用annotate获取额外字段。

from django.db.models import Max
queryset = Priekabos.objects.annotate(max_kada_moketi=Max('grafikas__kada_moketi'))
table = PriekabosTable(queryset)

请记住将该字段添加到您的表格中。

class PriekabosTable(tables.Table):
    class Meta:
        model = Priekabos
        attrs = {"class": "paleblue"}
        fields = ('id', 'sutarties_nr', 'nuomos_pradz', 'max_kada_moketi')