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,908
15년 전 조회 2,090
15년 전 조회 1,669
15년 전 조회 1,905
15년 전 조회 2,384
15년 전 조회 1,468
15년 전 조회 2,399
15년 전 조회 1,736
15년 전 조회 1,836
15년 전 조회 1,490
15년 전 조회 2,176
15년 전 조회 1,507
15년 전 조회 1,923
16년 전 조회 2,113
16년 전 조회 1,186
16년 전 조회 1,251
16년 전 조회 1,899
16년 전 조회 5,339
16년 전 조회 1,636
16년 전 조회 2,148
16년 전 조회 2,348
16년 전 조회 1,498
16년 전 조회 1,308
16년 전 조회 2,222
16년 전 조회 4,935
16년 전 조회 2,212
16년 전 조회 2,867
16년 전 조회 1,748
16년 전 조회 3,599
16년 전 조회 4,442
16년 전 조회 3,105
16년 전 조회 2,352
16년 전 조회 2,434
16년 전 조회 2,683
16년 전 조회 2,171
16년 전 조회 5,512
16년 전 조회 3,366
16년 전 조회 1,360
16년 전 조회 1,701
16년 전 조회 5,076
16년 전 조회 2,310
16년 전 조회 3,413
16년 전 조회 2,646
16년 전 조회 1,566
16년 전 조회 5,359
16년 전 조회 2,478
16년 전 조회 5,967
16년 전 조회 1,943
16년 전 조회 4,016
16년 전 조회 3,035
16년 전 조회 2,218
16년 전 조회 2,237
16년 전 조회 4,405
16년 전 조회 3,301
16년 전 조회 2,836
16년 전 조회 2,972
16년 전 조회 2,089
16년 전 조회 1,770
16년 전 조회 1,682
16년 전 조회 1,405
16년 전 조회 1,678
16년 전 조회 1,904
16년 전 조회 1,598
16년 전 조회 4,847
16년 전 조회 3,828
16년 전 조회 1,795
16년 전 조회 1,539
16년 전 조회 2,276
16년 전 조회 4,520
16년 전 조회 3,548
16년 전 조회 2,583
16년 전 조회 4,344
16년 전 조회 3,206
16년 전 조회 1,354
16년 전 조회 1,377
16년 전 조회 2,039
16년 전 조회 1,884
16년 전 조회 2,565
16년 전 조회 2,236
16년 전 조회 1,366
16년 전 조회 4,385
16년 전 조회 1,481
16년 전 조회 1,785
16년 전 조회 2,210
16년 전 조회 3,844
16년 전 조회 2,740
16년 전 조회 1,493
16년 전 조회 4,014
16년 전 조회 1,397
16년 전 조회 1,580
16년 전 조회 1,248
16년 전 조회 1,720
16년 전 조회 1,620
16년 전 조회 1,635
16년 전 조회 1,423
16년 전 조회 2,178
16년 전 조회 1,821
16년 전 조회 1,976
16년 전 조회 2,187
16년 전 조회 1,473
🐛 버그신고