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,900
15년 전 조회 2,086
15년 전 조회 1,664
15년 전 조회 1,899
15년 전 조회 2,381
15년 전 조회 1,465
15년 전 조회 2,397
15년 전 조회 1,734
15년 전 조회 1,831
15년 전 조회 1,484
15년 전 조회 2,173
15년 전 조회 1,502
15년 전 조회 1,921
16년 전 조회 2,111
16년 전 조회 1,185
16년 전 조회 1,248
16년 전 조회 1,893
16년 전 조회 5,336
16년 전 조회 1,634
16년 전 조회 2,143
16년 전 조회 2,345
16년 전 조회 1,495
16년 전 조회 1,304
16년 전 조회 2,218
16년 전 조회 4,931
16년 전 조회 2,206
16년 전 조회 2,865
16년 전 조회 1,745
16년 전 조회 3,598
16년 전 조회 4,436
16년 전 조회 3,103
16년 전 조회 2,350
16년 전 조회 2,430
16년 전 조회 2,682
16년 전 조회 2,166
16년 전 조회 5,508
16년 전 조회 3,364
16년 전 조회 1,353
16년 전 조회 1,697
16년 전 조회 5,072
16년 전 조회 2,303
16년 전 조회 3,409
16년 전 조회 2,645
16년 전 조회 1,560
16년 전 조회 5,355
16년 전 조회 2,473
16년 전 조회 5,963
16년 전 조회 1,941
16년 전 조회 4,013
16년 전 조회 3,032
16년 전 조회 2,215
16년 전 조회 2,235
16년 전 조회 4,403
16년 전 조회 3,297
16년 전 조회 2,831
16년 전 조회 2,969
16년 전 조회 2,084
16년 전 조회 1,769
16년 전 조회 1,681
16년 전 조회 1,404
16년 전 조회 1,673
16년 전 조회 1,901
16년 전 조회 1,593
16년 전 조회 4,841
16년 전 조회 3,825
16년 전 조회 1,792
16년 전 조회 1,534
16년 전 조회 2,273
16년 전 조회 4,516
16년 전 조회 3,543
16년 전 조회 2,580
16년 전 조회 4,341
16년 전 조회 3,203
16년 전 조회 1,353
16년 전 조회 1,375
16년 전 조회 2,038
16년 전 조회 1,883
16년 전 조회 2,560
16년 전 조회 2,231
16년 전 조회 1,360
16년 전 조회 4,380
16년 전 조회 1,479
16년 전 조회 1,782
16년 전 조회 2,207
16년 전 조회 3,840
16년 전 조회 2,735
16년 전 조회 1,489
16년 전 조회 4,013
16년 전 조회 1,394
16년 전 조회 1,577
16년 전 조회 1,246
16년 전 조회 1,718
16년 전 조회 1,616
16년 전 조회 1,631
16년 전 조회 1,420
16년 전 조회 2,174
16년 전 조회 1,817
16년 전 조회 1,970
16년 전 조회 2,184
16년 전 조회 1,469
🐛 버그신고