집 >데이터 베이스 >MySQL 튜토리얼 >mysql에서 그룹화하고 합산하는 방법
mysql에서는 SUM() 함수 및 "GROUP BY"와 함께 SELECT 문을 사용하여 그룹 합계를 수행할 수 있습니다. 구문은 "SELECT 쿼리 필드 SUM(합계 필드) AS 필드 FROM 테이블 이름 WHERE 조건 GROUP BY 그룹 필드입니다. 하나, 그룹화 필드 2;".
이 튜토리얼의 운영 환경: windows10 시스템, mysql8.0.22 버전, Dell G3 컴퓨터.
mysql에서는
SELECT 查询字段 SUM(求和字段) AS 字段 FROM 表名 WHERE 条件 GROUP BY 分组字段一,分组字段二;
을 사용하여 그룹 합계를 수행할 수 있습니다.
예는 다음과 같습니다.
1) count()는 특정 열의 행 수를 찾습니다.
count(열 이름)는 특정 열의 행 수를 찾는 것입니다. 이 열은 빈 값 행 수로 계산되지 않습니다. 예:
>-- 교사가 몇 명인지 쿼리
>-- 교사 테이블에 행이 몇 개 있는지 쿼리 SELECT COUNT(*) FROM Teacher;
열에 중복된 값이 있으면 카운트하고중복된 값을 계산하고 싶지 않습니다, 어떻게 해야 할까요?
-- 查询成绩表里共有几个学生的成绩 SELECT COUNT(DISTINCT 学号) FROM score;
2) sum()은 특정 열의 데이터를 합산합니다.
Sum은 특정 열의 값을 합산하는 것이며 값만 계산할 수 있습니다. 예:
-- 对所有成绩求和 SELECT SUM(成绩) FROM score;
3) avg()는 특정 값 열의 평균을 찾습니다.
마찬가지로 평균 계산은 숫자 값에서만 수행할 수 있습니다.
-- 对所有成绩求平均值 SELECT AVG(成绩) FROM score;
4) max()는 특정 데이터 열의 최대값을 찾고 min()은 특정 데이터 열의 최소값을 찾습니다
-- 获取所有成绩中的最大成绩 SELECT MAX(成绩),MIN(成绩) FROM score;
질문에서 우리가 알아야 할 사항을 언급했습니다. 각 과목의 평균 점수를 구한 다음 그룹화해야 합니다.
SQL에서 그룹별 문은 하나 이상의 열에 따라 결과 집합을 그룹화할 수 있습니다. 예:
-- 计算每一科课程的平均成绩 SELECT 课程号,AVG(成绩) FROM score GROUP BY 课程号;
이전 기사에서 SQL 문의 실행 순서를 간략하게 소개했습니다. 먼저 어느 테이블에서 데이터를 가져올지 실행한 다음 select 문을 실행합니다.
점수 테이블에서 데이터를 가져오고, 그룹화를 사용하여 특정 규칙에 따라 데이터를 그룹화한 다음 그룹화된 결과에 대해 count()를 계산하고 마지막으로 이전의 각 계산 결과 집합을 요약합니다. 테이블에 들어서세요.
첫 번째 문제에서는 "각 과목의 평균점수를 계산하여 80점 이상의 평균점수를 얻어야 합니다"라는 조건이 위 두 항목에서 나왔습니다. 매일 과목의 평균 점수 계산 이제 평균 점수 조건을 지정하려면: "80점 이상"
,Having 절과 where 절은 모두 조건부로 데이터를 선택합니다. 차이점은 where를 요약 함수와 함께 사용할 수 없다는 것입니다.
-- 计算平均成绩大于等于80分的课程; SELECT 课程号,AVG(成绩) FROM score GROUP BY 课程号 HAVING AVG(成绩)>=80;have절의 순서도 select 결과 요약보다 앞에 있다는 뜻인가요? 예, have 절은 80보다 크거나 같은 점수를 요구하는 등 그룹화 기준의 그룹화 결과에 대한 조건을 지정합니다. 결과를 필터링한 후 결과가 요약됩니다.
-- 对教师表根据教师姓名排序 SELECT * FROM teacher ORDER BY 教师姓名;
null 값 Null이 가장 먼저 순위가 매겨지는 것을 확인했습니다. 따라서:
null 값이 포함된 열을 정렬하면 null 값 null이 시작 부분에 있게 됩니다.데이터 양이 큰 경우 null 값을 보고 싶은 경우 이 정렬을 사용할 수 있습니다.
另外,在补充一个limit语句,从查询结果中取出指定行,比如,我们如果从刚才的查询结果中只取第一行:
-- 计算平均成绩大于等于80分的课程并根据成绩降序排,并获取第一行 SELECT 课程号,AVG(成绩) FROM score GROUP BY 课程号 HAVING AVG(成绩)>=80 ORDER BY AVG(成绩) DESC LIMIT 1;
接下来我们进行一个总结。
简单来说:明确问题,将问题翻译成大白话,逐步进行拆解,并写出分析思路和对应的SQL思路。
1) 明确问题,将问题翻译成大白话:
“计算各科的平均成绩并且得出平均成绩大于等于80分的课程并降序排列”翻译成大白话就是:
“计算每一门课程的平均成绩,然后根据得出的结果,进行大于等于80分的条件查询,对查询结果进行降序排列”。
2) 逐步进行拆解,并写出分析思路和对应的SQL思路:
① 对课程号进行分组,计算每一门课程的平均成绩;
② 对①的结果指定条件“>=80”;
③ 对②的结果进行降序排列;
我们可以把拆解后的思路套用到下方的公式中:
select 查询结果 from 从那张表中查找数据 where 查询条件(运算符、模糊查询) group by 分组(每个) having 对分组结果指定条件 order by 对查询结果排序 limit 从查询结果中取出指定行;
试一下吧:
select 查询结果[课程号,avg(成绩)] from 从那张表中查找数据[成绩表score] where 查询条件(运算符、模糊查询)[No] group by 分组(每个)[课程号] having 对分组结果指定条件[avg(成绩)>=80] order by 对查询结果排序[avg(成绩)desc] limit 从查询结果中取出指定行;[No]
这样子,问题是不是就迎刃而解呢?
推荐学习:mysql视频教程
위 내용은 mysql에서 그룹화하고 합산하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!