>백엔드 개발 >파이썬 튜토리얼 >집계를 사용하여 Django에서 Group By 쿼리를 어떻게 수행할 수 있나요?

집계를 사용하여 Django에서 Group By 쿼리를 어떻게 수행할 수 있나요?

Barbara Streisand
Barbara Streisand원래의
2024-12-06 02:51:11526검색

How Can I Perform Group By Queries in Django Using Aggregation?

Django의 쿼리별 그룹화

Django의 쿼리 세트 API를 패치하지 않고도 ORM의 집계 기능을 사용하여 기능별 그룹화를 달성할 수 있습니다.

집계 값 및 개수 사용

특정 필드별로 결과를 그룹화하고 각 그룹의 발생 횟수를 계산하려면 다음 구문을 사용하세요.

from django.db.models import Count
result = (Members.objects
    .values('designation')
    .annotate(dcount=Count('designation'))
    .order_by()
)

이렇게 하면 다음과 같은 쿼리 세트가 반환됩니다. 각 지정 횟수와 함께 지정 필드별로 그룹화된 결과입니다. 출력은 각각 지정 및 dcount(지정 개수)를 포함하는 사전 목록입니다.

결과에 여러 필드 포함

여러 필드를 포함하려면 결과에서 간단히 value()에 인수로 추가하면 됩니다. 함수:

    .values('designation', 'first_name', 'last_name')

참조

  • [Django 문서: 값()](https://docs.djangoproject.com/en/ stable/ref/models/querysets/#values)
  • [Django 문서: annotate()](https://docs.djangoproject.com/en/stable/ref/models/querysets/#annotate)
  • [Django 문서: 개수](https://docs.djangoproject.com /en/stable/ref/models/lookups/#count)
  • [Django 문서: 집계](https://docs.djangoproject.com/en/stable/topics/db/aggregation/)
  • [Django 문서: 기본 순서 또는 order_by()와의 상호 작용](https://docs. djangoproject.com/en/stable/topics/db/aggregation/#interaction-with-default-ordering-or-orderby)

위 내용은 집계를 사용하여 Django에서 Group By 쿼리를 어떻게 수행할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.