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,259
16년 전 조회 2,421
16년 전 조회 2,009
16년 전 조회 2,208
16년 전 조회 2,712
16년 전 조회 1,793
16년 전 조회 2,722
16년 전 조회 2,047
16년 전 조회 2,177
16년 전 조회 1,820
16년 전 조회 2,520
16년 전 조회 1,839
16년 전 조회 2,263
16년 전 조회 2,423
16년 전 조회 1,514
16년 전 조회 1,580
16년 전 조회 2,232
16년 전 조회 5,649
16년 전 조회 1,947
16년 전 조회 2,476
16년 전 조회 2,668
16년 전 조회 1,827
16년 전 조회 1,610
16년 전 조회 2,540
16년 전 조회 5,253
16년 전 조회 2,526
16년 전 조회 3,179
16년 전 조회 2,055
16년 전 조회 3,927
16년 전 조회 4,755
16년 전 조회 3,387
16년 전 조회 2,636
16년 전 조회 2,743
16년 전 조회 2,975
16년 전 조회 2,490
16년 전 조회 5,860
16년 전 조회 3,676
16년 전 조회 1,666
16년 전 조회 2,009
16년 전 조회 5,367
16년 전 조회 2,634
16년 전 조회 3,700
16년 전 조회 2,985
16년 전 조회 1,859
16년 전 조회 5,684
16년 전 조회 2,800
16년 전 조회 6,272
16년 전 조회 2,248
16년 전 조회 4,297
16년 전 조회 3,321
16년 전 조회 2,510
16년 전 조회 2,519
16년 전 조회 4,685
16년 전 조회 3,585
16년 전 조회 3,114
16년 전 조회 3,255
16년 전 조회 2,383
16년 전 조회 2,046
16년 전 조회 1,969
16년 전 조회 1,679
16년 전 조회 1,982
16년 전 조회 2,192
16년 전 조회 1,884
16년 전 조회 5,129
16년 전 조회 4,143
16년 전 조회 2,069
16년 전 조회 1,844
16년 전 조회 2,561
16년 전 조회 4,840
16년 전 조회 3,831
16년 전 조회 2,872
16년 전 조회 4,603
16년 전 조회 3,471
16년 전 조회 1,639
16년 전 조회 1,661
16년 전 조회 2,323
16년 전 조회 2,168
16년 전 조회 2,895
16년 전 조회 2,499
16년 전 조회 1,630
16년 전 조회 4,679
16년 전 조회 1,764
16년 전 조회 2,071
16년 전 조회 2,487
16년 전 조회 4,160
16년 전 조회 3,053
16년 전 조회 1,763
16년 전 조회 4,327
16년 전 조회 1,680
16년 전 조회 1,852
16년 전 조회 1,528
16년 전 조회 1,989
16년 전 조회 1,901
16년 전 조회 1,910
16년 전 조회 1,693
16년 전 조회 2,453
16년 전 조회 2,073
16년 전 조회 2,249
16년 전 조회 2,472
16년 전 조회 1,753