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,893
15년 전 조회 2,078
15년 전 조회 1,655
15년 전 조회 1,891
15년 전 조회 2,371
15년 전 조회 1,456
15년 전 조회 2,390
15년 전 조회 1,724
15년 전 조회 1,820
15년 전 조회 1,474
15년 전 조회 2,164
15년 전 조회 1,493
15년 전 조회 1,908
15년 전 조회 2,101
15년 전 조회 1,178
15년 전 조회 1,236
15년 전 조회 1,880
15년 전 조회 5,325
16년 전 조회 1,627
16년 전 조회 2,136
16년 전 조회 2,336
16년 전 조회 1,484
16년 전 조회 1,293
16년 전 조회 2,207
16년 전 조회 4,922
16년 전 조회 2,199
16년 전 조회 2,856
16년 전 조회 1,736
16년 전 조회 3,588
16년 전 조회 4,426
16년 전 조회 3,095
16년 전 조회 2,341
16년 전 조회 2,421
16년 전 조회 2,671
16년 전 조회 2,158
16년 전 조회 5,501
16년 전 조회 3,351
16년 전 조회 1,344
16년 전 조회 1,689
16년 전 조회 5,060
16년 전 조회 2,297
16년 전 조회 3,400
16년 전 조회 2,634
16년 전 조회 1,553
16년 전 조회 5,345
16년 전 조회 2,461
16년 전 조회 5,952
16년 전 조회 1,928
16년 전 조회 4,005
16년 전 조회 3,020
16년 전 조회 2,205
16년 전 조회 2,225
16년 전 조회 4,402
16년 전 조회 3,285
16년 전 조회 2,822
16년 전 조회 2,954
16년 전 조회 2,073
16년 전 조회 1,760
16년 전 조회 1,670
16년 전 조회 1,393
16년 전 조회 1,665
16년 전 조회 1,893
16년 전 조회 1,585
16년 전 조회 4,835
16년 전 조회 3,817
16년 전 조회 1,782
16년 전 조회 1,526
16년 전 조회 2,261
16년 전 조회 4,509
16년 전 조회 3,536
16년 전 조회 2,571
16년 전 조회 4,329
16년 전 조회 3,198
16년 전 조회 1,346
16년 전 조회 1,364
16년 전 조회 2,027
16년 전 조회 1,874
16년 전 조회 2,551
16년 전 조회 2,222
16년 전 조회 1,352
16년 전 조회 4,374
16년 전 조회 1,467
16년 전 조회 1,774
16년 전 조회 2,193
16년 전 조회 3,827
16년 전 조회 2,724
16년 전 조회 1,481
16년 전 조회 4,004
16년 전 조회 1,386
16년 전 조회 1,570
16년 전 조회 1,234
16년 전 조회 1,709
16년 전 조회 1,605
16년 전 조회 1,623
16년 전 조회 1,412
16년 전 조회 2,166
16년 전 조회 1,808
16년 전 조회 1,961
16년 전 조회 2,173
16년 전 조회 1,459
🐛 버그신고