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

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

Barbara Streisand
풀어 주다: 2024-12-06 02:51:11
원래의
503명이 탐색했습니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿