我想对所有的医生进行专业化计数,并将其显示在管理面板中。
这是模型
class Doctor(models.Model):
name = models.CharField(max_length=1300)
specialization = models.ForeignKey(Specialization)
clinic = models.ForeignKey(Clinic)
class Specialization(models.Model):
name = models.CharField(max_length=30)例如,我想展示如下:
皮肤科医生: 10人
眼科医生: 15人
我对Django非常陌生,不知道该怎么做。
发布于 2014-12-10 12:44:28
不要使用obj.doctor_set.count()配方。将对每个专门化记录调用此方法。
将单个SQL查询与聚合一起使用:
# admin.py
from django.contrib import admin
from django.db.models import Count
from app.models import Specialization
class SpecializationAdmin(admin.ModelAdmin):
list_display = ['name', 'doctor_count_display']
def get_queryset(self, request):
qs = super(SpecializationAdmin, self).get_queryset(request)
return qs.annotate(doctor_count=Count('doctor')).order_by('-doctor_count')
def doctor_count_display(self, obj):
return obj.doctor_count
doctor_count_display.short_description = 'Number of doctors'
doctor_count_display.admin_order_field = 'doctor_count'
admin.site.register(Specialization, SpecializationAdmin)发布于 2014-12-10 12:34:08
您可以以这样的方式完成这一任务,例如:
#admin.py
class SpecializationAdmin(admin.ModelAdmin):
list_display = ('get_count',)
def get_count(self, obj):
return u"{}: {}".format(obj.name, obj.doctor_set.count())
get_count.short_description = "Number of Doctors"并注册如下:
# also in admin.py
admin.site.register(Specialization, SpecializationAdmin)不要忘记将Specialization模型导入到admin.py中
发布于 2014-12-10 12:34:01
您需要了解有关查询Django查询的信息
为了显示皮肤科医生的人数:
Doctor.objects.filter(specialization__name="Dermatologist").count()显示眼科医生的人数
Doctor.objects.filter(specialization__name="Ophthalmologist").count()https://stackoverflow.com/questions/27400887
复制相似问题