group by 를 이용한 학생들 과목 총점, 평점 만들기 예제

학생들 과목 총점, 평점 만들기 예제

create table subtable(
name varchar(30),
subject char(4),
point int);

insert into subtable values('홍길동','수학',90);
insert into subtable values('홍길동','영어',60);
insert into subtable values('홍길동','국어',80);
insert into subtable values('김철수','수학',100);
insert into subtable values('김철수','영어',80);
insert into subtable values('김철수','국어',50);
insert into subtable values('김영희','수학',100);
insert into subtable values('김영희','영어',100);
insert into subtable values('김영희','국어',100);


mysql> select * from subtable;
+--------+---------+-------+
| name   | subject | point |
+--------+---------+-------+
| 홍길동 | 수학    |    90 |
| 홍길동 | 영어    |    60 |
| 홍길동 | 국어    |    80 |
| 김철수 | 수학    |   100 |
| 김철수 | 영어    |    80 |
| 김철수 | 국어    |    50 |
| 김영희 | 수학    |   100 |
| 김영희 | 영어    |   100 |
| 김영희 | 국어    |   100 |
+--------+---------+-------+
9 rows in set (0.00 sec)


mysql> select distinct(name) as 이름, sum(point) as 총점, sum(point)/3 as 평점 from subtable group by name;
+--------+------------+
| name   | sum(point) |
+--------+------------+
| 김영희 |        300 |
| 김철수 |        230 |
| 홍길동 |        230 |
+--------+------------+
3 rows in set (0.00 sec)


mysql> select distinct(name) as 이름, sum(point) as 총점, sum(point)/3 as 평점 fm subtable group by name;
+--------+------+----------+
| 이름   | 총점 | 평점     |
+--------+------+----------+
| 김영희 |  300 | 100.0000 |
| 김철수 |  230 |  76.6667 |
| 홍길동 |  230 |  76.6667 |
+--------+------+----------+
3 rows in set (0.00 sec)

출처 : http://www.sqldic.co.kr/sqldicView.action?sqldic.bbs_seq=446&page=1

[이 게시물은 관리자님에 의해 2011-10-31 17:27:00 MySQL에서 이동 됨]
|

댓글 2개

group by 하면 distinct는 필요없어요.
PHP 5.3.0 부터는 바뀐게 많아서..
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
15년 전 조회 2,898
15년 전 조회 2,084
15년 전 조회 1,660
15년 전 조회 1,896
15년 전 조회 2,379
15년 전 조회 1,462
15년 전 조회 2,394
15년 전 조회 1,728
15년 전 조회 1,828
15년 전 조회 1,479
15년 전 조회 2,170
15년 전 조회 1,498
15년 전 조회 1,917
16년 전 조회 2,107
16년 전 조회 1,183
16년 전 조회 1,242
16년 전 조회 1,887
16년 전 조회 5,332
16년 전 조회 1,633
16년 전 조회 2,140
16년 전 조회 2,342
16년 전 조회 1,489
16년 전 조회 1,300
16년 전 조회 2,213
16년 전 조회 4,930
16년 전 조회 2,204
16년 전 조회 2,858
16년 전 조회 1,742
16년 전 조회 3,594
16년 전 조회 4,432
16년 전 조회 3,100
16년 전 조회 2,345
16년 전 조회 2,428
16년 전 조회 2,677
16년 전 조회 2,162
16년 전 조회 5,505
16년 전 조회 3,358
16년 전 조회 1,350
16년 전 조회 1,696
16년 전 조회 5,067
16년 전 조회 2,301
16년 전 조회 3,408
16년 전 조회 2,639
16년 전 조회 1,557
16년 전 조회 5,354
16년 전 조회 2,466
16년 전 조회 5,959
16년 전 조회 1,937
16년 전 조회 4,011
16년 전 조회 3,026
16년 전 조회 2,211
16년 전 조회 2,231
16년 전 조회 4,403
16년 전 조회 3,292
16년 전 조회 2,827
16년 전 조회 2,965
16년 전 조회 2,081
16년 전 조회 1,766
16년 전 조회 1,678
16년 전 조회 1,398
16년 전 조회 1,669
16년 전 조회 1,900
16년 전 조회 1,589
16년 전 조회 4,839
16년 전 조회 3,820
16년 전 조회 1,788
16년 전 조회 1,532
16년 전 조회 2,271
16년 전 조회 4,513
16년 전 조회 3,538
16년 전 조회 2,578
16년 전 조회 4,335
16년 전 조회 3,202
16년 전 조회 1,352
16년 전 조회 1,369
16년 전 조회 2,032
16년 전 조회 1,879
16년 전 조회 2,558
16년 전 조회 2,227
16년 전 조회 1,359
16년 전 조회 4,377
16년 전 조회 1,474
16년 전 조회 1,779
16년 전 조회 2,200
16년 전 조회 3,836
16년 전 조회 2,731
16년 전 조회 1,485
16년 전 조회 4,008
16년 전 조회 1,392
16년 전 조회 1,575
16년 전 조회 1,240
16년 전 조회 1,714
16년 전 조회 1,612
16년 전 조회 1,627
16년 전 조회 1,417
16년 전 조회 2,174
16년 전 조회 1,813
16년 전 조회 1,968
16년 전 조회 2,178
16년 전 조회 1,466
🐛 버그신고