> 백엔드 개발 > 파이썬 튜토리얼 > Django에서 Group By 쿼리를 어떻게 수행합니까?

Django에서 Group By 쿼리를 어떻게 수행합니까?

DDD
풀어 주다: 2024-12-05 18:07:10
원래의
235명이 탐색했습니다.

How Do I Perform Group By Queries in Django?

Django의 Group By 쿼리

Background

Django 모델을 쿼리할 때 작업별로 그룹을 수행해야 하는 시나리오가 발생할 수 있습니다. . SQL에서와 마찬가지로 .group_by()를 사용하려고 하면 오류가 발생합니다.

집계 기능

Django는 .group_by()를 사용하는 대신 복잡한 쿼리를 수행할 수 있는 집계 방법을 제공합니다. 그룹화를 포함합니다. 특히 Count는 특정 필드의 발생 횟수를 계산하는 데 유용합니다.

지정별로 결과를 그룹화하고 발생 횟수를 계산하려면 다음 코드를 사용합니다.

from django.db.models import Count

result = (Members.objects
    .values('designation')
    .annotate(dcount=Count('designation'))
    .order_by()
)
로그인 후 복사

이 쿼리는 다음 SQL 문과 유사합니다.

SELECT designation, COUNT(designation) AS dcount
FROM members GROUP BY designation
로그인 후 복사

Django 쿼리의 출력 형식은 다음과 같습니다.

[{'designation': 'Salesman', 'dcount': 2}, 
 {'designation': 'Manager', 'dcount': 2}]
로그인 후 복사

추가 참고 사항

  • 올바른 정렬을 보장하려면 order_by()를 포함하세요.
  • 결과에 여러 필드를 포함하려면 다음을 전달하세요. .values()에 대한 인수로 사용됩니다.
  • values()에 대한 Django 문서를 참조하세요. 자세한 정보를 보려면 주석()을 달고 계산하세요.

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

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