>백엔드 개발 >파이썬 튜토리얼 >Django에서 GROUP BY 쿼리를 수행하는 방법은 무엇입니까?

Django에서 GROUP BY 쿼리를 수행하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-11 02:22:09594검색

How to Perform GROUP BY Queries in Django?

Django에서 Group By 쿼리를 수행하는 방법은 무엇입니까?

Django에서 모델에 대한 쿼리별 그룹을 수행하려면 다음을 사용할 수 있습니다. ORM의 집계 기능. 이는 value() 및 annotate() 메소드를 활용하여 달성됩니다.

다음 예를 고려하십시오.

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

쿼리 결과는 각각 그룹을 나타내는 사전 개체 목록이 됩니다. 예를 들어:

[{'designation': 'Salesman', 'dcount': 2}, 
 {'designation': 'Manager', 'dcount': 2}]

결과에 여러 필드를 포함하려면 해당 필드를 value()에 인수로 추가하면 됩니다.

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

참조:

  • Django 문서: 값(), 주석() 및 Count
  • Django 문서: 집계, 특히 기본 순서 또는 order_by()와의 상호 작용 섹션

위 내용은 Django에서 GROUP BY 쿼리를 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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