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 부터는 바뀐게 많아서..
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
16년 전 조회 3,185
16년 전 조회 2,350
16년 전 조회 1,935
16년 전 조회 2,143
16년 전 조회 2,646
16년 전 조회 1,723
16년 전 조회 2,643
16년 전 조회 1,971
16년 전 조회 2,102
16년 전 조회 1,752
16년 전 조회 2,446
16년 전 조회 1,771
16년 전 조회 2,190
16년 전 조회 2,352
16년 전 조회 1,443
16년 전 조회 1,510
16년 전 조회 2,158
16년 전 조회 5,577
16년 전 조회 1,881
16년 전 조회 2,403
16년 전 조회 2,600
16년 전 조회 1,753
16년 전 조회 1,543
16년 전 조회 2,463
16년 전 조회 5,174
16년 전 조회 2,449
16년 전 조회 3,111
16년 전 조회 1,981
16년 전 조회 3,852
16년 전 조회 4,689
16년 전 조회 3,335
16년 전 조회 2,572
16년 전 조회 2,665
16년 전 조회 2,908
16년 전 조회 2,414
16년 전 조회 5,801
16년 전 조회 3,606
16년 전 조회 1,598
16년 전 조회 1,935
16년 전 조회 5,304
16년 전 조회 2,559
16년 전 조회 3,633
16년 전 조회 2,917
16년 전 조회 1,784
16년 전 조회 5,630
16년 전 조회 2,745
16년 전 조회 6,202
16년 전 조회 2,167
16년 전 조회 4,238
16년 전 조회 3,265
16년 전 조회 2,445
16년 전 조회 2,459
16년 전 조회 4,634
16년 전 조회 3,518
16년 전 조회 3,055
16년 전 조회 3,195
16년 전 조회 2,317
16년 전 조회 1,992
16년 전 조회 1,911
16년 전 조회 1,616
16년 전 조회 1,916
16년 전 조회 2,128
16년 전 조회 1,823
16년 전 조회 5,063
16년 전 조회 4,090
16년 전 조회 2,013
16년 전 조회 1,774
16년 전 조회 2,494
16년 전 조회 4,781
16년 전 조회 3,765
16년 전 조회 2,808
16년 전 조회 4,541
16년 전 조회 3,411
16년 전 조회 1,577
16년 전 조회 1,592
16년 전 조회 2,256
16년 전 조회 2,103
16년 전 조회 2,839
16년 전 조회 2,442
16년 전 조회 1,574
16년 전 조회 4,620
16년 전 조회 1,708
16년 전 조회 2,011
16년 전 조회 2,423
16년 전 조회 4,107
16년 전 조회 2,995
16년 전 조회 1,702
16년 전 조회 4,280
16년 전 조회 1,613
16년 전 조회 1,784
16년 전 조회 1,464
16년 전 조회 1,932
16년 전 조회 1,844
16년 전 조회 1,843
16년 전 조회 1,628
16년 전 조회 2,393
16년 전 조회 2,012
16년 전 조회 2,183
16년 전 조회 2,410
16년 전 조회 1,682