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,421
16년 전 조회 2,588
16년 전 조회 2,179
16년 전 조회 2,378
16년 전 조회 2,879
16년 전 조회 1,974
16년 전 조회 2,891
16년 전 조회 2,222
16년 전 조회 2,340
16년 전 조회 1,963
16년 전 조회 2,682
16년 전 조회 1,997
16년 전 조회 2,419
16년 전 조회 2,593
16년 전 조회 1,660
16년 전 조회 1,728
16년 전 조회 2,401
16년 전 조회 5,810
16년 전 조회 2,128
16년 전 조회 2,649
16년 전 조회 2,830
16년 전 조회 1,992
16년 전 조회 1,780
16년 전 조회 2,694
16년 전 조회 5,410
16년 전 조회 2,684
16년 전 조회 3,336
16년 전 조회 2,209
16년 전 조회 4,092
16년 전 조회 4,895
16년 전 조회 3,539
16년 전 조회 2,794
16년 전 조회 2,911
16년 전 조회 3,124
16년 전 조회 2,639
16년 전 조회 5,991
16년 전 조회 3,813
16년 전 조회 1,817
16년 전 조회 2,146
16년 전 조회 5,515
16년 전 조회 2,764
16년 전 조회 3,843
16년 전 조회 3,117
16년 전 조회 2,019
16년 전 조회 5,830
16년 전 조회 2,933
16년 전 조회 6,423
16년 전 조회 2,399
16년 전 조회 4,453
16년 전 조회 3,455
16년 전 조회 2,650
16년 전 조회 2,673
16년 전 조회 4,806
16년 전 조회 3,742
16년 전 조회 3,267
16년 전 조회 3,421
16년 전 조회 2,533
16년 전 조회 2,205
16년 전 조회 2,128
16년 전 조회 1,835
16년 전 조회 2,116
16년 전 조회 2,328
16년 전 조회 2,031
16년 전 조회 5,282
16년 전 조회 4,272
16년 전 조회 2,224
16년 전 조회 1,966
16년 전 조회 2,722
16년 전 조회 4,970
16년 전 조회 3,977
16년 전 조회 3,011
16년 전 조회 4,758
16년 전 조회 3,608
16년 전 조회 1,765
16년 전 조회 1,799
16년 전 조회 2,467
16년 전 조회 2,313
16년 전 조회 3,024
16년 전 조회 2,637
16년 전 조회 1,777
16년 전 조회 4,815
16년 전 조회 1,896
16년 전 조회 2,207
16년 전 조회 2,636
16년 전 조회 4,287
16년 전 조회 3,190
16년 전 조회 1,906
16년 전 조회 4,453
16년 전 조회 1,809
16년 전 조회 1,994
16년 전 조회 1,662
16년 전 조회 2,141
16년 전 조회 2,057
16년 전 조회 2,046
16년 전 조회 1,822
16년 전 조회 2,588
16년 전 조회 2,225
16년 전 조회 2,384
16년 전 조회 2,614
16년 전 조회 1,874