2

我希望编写一个通用函数,给定一个查询集,返回模型每一列的不同字段的数量。

我到目前为止的功能是:

[queryset.aggregate(Count(x, distinct=True)) for x in [x.get_attname() for x in queryset.model._meta._fields()]]

然而,这相当hacky/丑陋/不清楚。我想知道是否有更简单/更清晰的方法来做到这一点?

谢谢。

4

1 回答 1

0

您可以将多个聚合传递给.aggregate,因此您可以这样做以减少对数据库的调用。下面的代码未经测试,只是为了说明我的意思。

args = [Count(x.get_attname(), distinct=True)) for x in queryset.model._meta._fields()]
queryset.aggregate(*args)
于 2012-07-23T13:35:30.500 回答