Django模型根据其他列的最大值获取唯一的外键行

时间:2017-04-06 10:35:27

标签: django django-models

我是Django的新手,我正在尝试创建一个简单的应用程序来跟踪SQlite数据库中的不同服务器配置。我创建了2个数据库模型:

from django.db import models

class Server(models.Model):
    name = models.CharField(max_length=250)

class Config(models.Model):
    server = models.ForeignKey(Server, on_delete=models.CASCADE)
    configuration = models.CharField(max_length=250)
    config_version = models.IntegerField()

以下是2个模型样本数据:

Server:
| id     | name    |
| ------ | ------  |
| 1      | Server1 |
| 2      | Server2 |
| 3      | Server3 |

Config:
| id     | configuration | config_version | server |
| ------ | ------------- | -------------- | ------ |
| 1      | srv1_cfg1     | 1              | 1      |
| 2      | srv2_cfg1     | 1              | 2      |
| 3      | srv2_cfg2     | 2              | 2      |
| 4      | srv2_cfg3     | 3              | 2      |
| 5      | srv3_cfg1     | 1              | 3      |
| 6      | srv1_cfg2     | 2              | 1      |
| 7      | srv1_cfg3     | 3              | 1      |

我想查询Config表,并且只获取每个服务器ID的最大值为“config_version”字段的行,如:

Desired result:
| id     | configuration | config_version | serverid | servername |
| ------ | ------------- | -------------- | -------- | ---------- |
| 4      | srv2_cfg3     | 3              | 2        | Server2    |
| 5      | srv3_cfg1     | 1              | 3        | Server3    |
| 7      | srv1_cfg3     | 3              | 1        | Server1    |

我尝试了很多不同的选项来构建正确的查询,但到目前为止我无法得到我想要的东西。我最好的结果是查询服务器表:

Server.objects.annotate(maxver=Max('config__config_version'))

但似乎我无法访问Config表对象,所以我想我需要通过一些过滤来查询Config表吗?

我可以使用原始SQL查询执行此操作,但我更倾向于使用“Django”方式。任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:0)

经过多次努力之后,我找到了一个适合我的解决方案。我确定它不是最佳的,但至少似乎有效:

from django.db.models import Max, F

s1 = Config.objects.annotate(maxver=Max('server__config__config_version'))
config_list = s1.filter(config_version=F('maxver'))

如果有更好的方法,我很想知道。