>  기사  >  데이터 베이스  >  Group By를 사용하여 MySql에서 여러 필드를 그룹화하는 방법

Group By를 사용하여 MySql에서 여러 필드를 그룹화하는 방법

黄舟
黄舟원래의
2018-05-25 15:31:147026검색

이 글은 주로 MySql Group By의 구현 방법을 소개하여 여러 필드를 그룹화합니다. 필요한 친구들은 참고해도 됩니다.

추천 관련 mysql 동영상 튜토리얼: "mysql tutorial"

일상적인 개발 작업에서 우리는 종종 MYSQL의 GROUP BY 그룹화를 사용하여 데이터 테이블의 그룹화 필드를 기반으로 통계 데이터를 얻습니다. 예를 들어 다음과 같은 구조의 학생 강좌 선택 테이블이 있습니다.

Table: Subject_Selection
Subject  Semester  Attendee
---------------------------------
ITB001  1     John
ITB001  1     Bob
ITB001  1     Mickey
ITB001  2     Jenny
ITB001  2     James
MKB114  1     John
MKB114  1     Erica

각 강좌에 등록한 학생 수를 계산하려고 합니다. 다음 SQL을 적용합니다.

SELECT Subject, Count(*)
FROM Subject_Selection
GROUP BY Subject

다음 결과가 얻어집니다.

Subject  Count
------------------------------
ITB001   5
MKB114   2

Because ITB001 테이블에는 5명의 학생 선택이 기록되어 있으며, 2명의 학생이 MKB114를 선택했습니다.

이 결과의 이유는 다음과 같습니다.

GROUP BY X는 동일한 X 필드 값을 가진 모든 레코드를 그룹에 넣는 것을 의미합니다.

GROUP BY X, Y는 어떻습니까?

GROUP BY X, Y는 X 필드 값과 Y 필드 값이 동일한 모든 레코드를 그룹으로 묶는 것을 의미합니다.

그런 다음 매 학기마다 각 과목을 선택한 사람의 수를 계산하고 다음 SQL을 적용합니다.

SELECT Subject, Semester, Count(*)
FROM Subject_Selection
GROUP BY Subject, Semester

위 SQL은 Subject_Selection 테이블의 데이터가 동일한 주제와 동일한 항목을 갖도록 그룹화된다는 의미입니다. 학기 필드 값. 레코드를 동일한 그룹에 넣은 다음 각 그룹의 데이터에 집계 함수(COUNT, SUM, AVG 등)를 적용합니다.

얻은 결과는 다음과 같습니다.

Subject  Semester  Count
------------------------------
ITB001   1     3
ITB001   2     2
MKB114   1     2

표의 기록을 보면 이 그룹화 결과가 1학기에 3명의 학생이 ITB001을 선택했고 2학기에 2명의 학생이 ITB001을 선택한 것을 알 수 있습니다.

첫 학기에 MKB114를 선택한 학생은 2명이고, 두 번째 학기에는 MKB114를 선택한 학생이 없습니다.

또 다른 예는 모든 결제된 주문을 기록하는 주문 테이블입니다.

테이블: Order

Product  Buyer    Spending
---------------------------------
PD001   Todd     12.00
PD001   Todd     12.00
PD001   Todd     12.00
PD001   Lily     12.00
PD001   Lily     12.00
PD002   Todd     20.00
PD002   Todd     20.00

이제 각 사용자가 각 제품에 지출한 총 금액을 계산하고 다음 SQL을 실행합니다.

SELECT Product,Buyer, SUM(Spending)
FROM `Order`
GROUP BY Product, Buyer

얻은 결과는 다음과 같습니다.

Product  Buyer   SUM
------------------------------
PD001   Todd   36.00
PD001   Lily   24.00
PD002   Todd   40.00

요약:

MYSQL에서 GROUP BY를 사용하여 테이블의 데이터를 그룹화할 때

GROUP BY X는 동일한 X 필드 값을 가진 모든 레코드를 하나로 묶는 것을 의미합니다.

GROUP BY X, Y는 X 필드 값과 Y 필드 값이 동일한 모든 레코드를 하나의 그룹에 넣는 것을 의미합니다.

위 내용은 Group By를 사용하여 MySql에서 여러 필드를 그룹화하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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