django mysql排序_Django admin:如何按照没有数据库字段的自定义list_display字段之一进行排序...

我喜欢Greg的这个问题的解决方案,但我想指出,你可以在管理员直接做同样的事情:

from django.db import models

class CustomerAdmin(admin.ModelAdmin):

list_display = ('number_of_orders',)

def get_queryset(self, request):

# def queryset(self, request): # For Django <1.6

qs = super(CustomerAdmin, self).get_queryset(request)

# qs = super(CustomerAdmin, self).queryset(request) # For Django <1.6

qs = qs.annotate(models.Count('order'))

return qs

def number_of_orders(self, obj):

return obj.order__count

number_of_orders.admin_order_field = 'order__count'

这样,您只需在管理界面中注释。不是每个查询都做。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值