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