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,911
15년 전 조회 2,093
15년 전 조회 1,673
15년 전 조회 1,908
15년 전 조회 2,390
15년 전 조회 1,472
15년 전 조회 2,407
15년 전 조회 1,739
15년 전 조회 1,839
15년 전 조회 1,493
15년 전 조회 2,176
15년 전 조회 1,510
15년 전 조회 1,925
16년 전 조회 2,116
16년 전 조회 1,188
16년 전 조회 1,256
16년 전 조회 1,902
16년 전 조회 5,342
16년 전 조회 1,641
16년 전 조회 2,154
16년 전 조회 2,351
16년 전 조회 1,505
16년 전 조회 1,310
16년 전 조회 2,227
16년 전 조회 4,940
16년 전 조회 2,214
16년 전 조회 2,870
16년 전 조회 1,754
16년 전 조회 3,606
16년 전 조회 4,444
16년 전 조회 3,109
16년 전 조회 2,355
16년 전 조회 2,440
16년 전 조회 2,687
16년 전 조회 2,174
16년 전 조회 5,516
16년 전 조회 3,372
16년 전 조회 1,363
16년 전 조회 1,706
16년 전 조회 5,078
16년 전 조회 2,313
16년 전 조회 3,417
16년 전 조회 2,653
16년 전 조회 1,570
16년 전 조회 5,361
16년 전 조회 2,479
16년 전 조회 5,971
16년 전 조회 1,948
16년 전 조회 4,019
16년 전 조회 3,037
16년 전 조회 2,224
16년 전 조회 2,241
16년 전 조회 4,407
16년 전 조회 3,302
16년 전 조회 2,839
16년 전 조회 2,975
16년 전 조회 2,093
16년 전 조회 1,774
16년 전 조회 1,686
16년 전 조회 1,409
16년 전 조회 1,682
16년 전 조회 1,911
16년 전 조회 1,604
16년 전 조회 4,848
16년 전 조회 3,832
16년 전 조회 1,801
16년 전 조회 1,545
16년 전 조회 2,281
16년 전 조회 4,523
16년 전 조회 3,551
16년 전 조회 2,585
16년 전 조회 4,346
16년 전 조회 3,211
16년 전 조회 1,360
16년 전 조회 1,381
16년 전 조회 2,044
16년 전 조회 1,888
16년 전 조회 2,572
16년 전 조회 2,239
16년 전 조회 1,370
16년 전 조회 4,389
16년 전 조회 1,484
16년 전 조회 1,789
16년 전 조회 2,214
16년 전 조회 3,850
16년 전 조회 2,745
16년 전 조회 1,499
16년 전 조회 4,021
16년 전 조회 1,403
16년 전 조회 1,583
16년 전 조회 1,253
16년 전 조회 1,725
16년 전 조회 1,625
16년 전 조회 1,636
16년 전 조회 1,429
16년 전 조회 2,181
16년 전 조회 1,826
16년 전 조회 1,980
16년 전 조회 2,188
16년 전 조회 1,477
🐛 버그신고