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,920
15년 전 조회 2,099
15년 전 조회 1,680
15년 전 조회 1,915
15년 전 조회 2,398
15년 전 조회 1,480
15년 전 조회 2,414
16년 전 조회 1,749
16년 전 조회 1,846
16년 전 조회 1,495
16년 전 조회 2,186
16년 전 조회 1,521
16년 전 조회 1,931
16년 전 조회 2,124
16년 전 조회 1,193
16년 전 조회 1,262
16년 전 조회 1,909
16년 전 조회 5,350
16년 전 조회 1,649
16년 전 조회 2,162
16년 전 조회 2,361
16년 전 조회 1,513
16년 전 조회 1,316
16년 전 조회 2,231
16년 전 조회 4,945
16년 전 조회 2,218
16년 전 조회 2,878
16년 전 조회 1,756
16년 전 조회 3,612
16년 전 조회 4,446
16년 전 조회 3,113
16년 전 조회 2,359
16년 전 조회 2,451
16년 전 조회 2,692
16년 전 조회 2,180
16년 전 조회 5,519
16년 전 조회 3,380
16년 전 조회 1,368
16년 전 조회 1,711
16년 전 조회 5,084
16년 전 조회 2,324
16년 전 조회 3,422
16년 전 조회 2,661
16년 전 조회 1,576
16년 전 조회 5,369
16년 전 조회 2,482
16년 전 조회 5,976
16년 전 조회 1,955
16년 전 조회 4,027
16년 전 조회 3,044
16년 전 조회 2,227
16년 전 조회 2,248
16년 전 조회 4,410
16년 전 조회 3,309
16년 전 조회 2,843
16년 전 조회 2,985
16년 전 조회 2,100
16년 전 조회 1,781
16년 전 조회 1,695
16년 전 조회 1,415
16년 전 조회 1,686
16년 전 조회 1,916
16년 전 조회 1,613
16년 전 조회 4,852
16년 전 조회 3,840
16년 전 조회 1,807
16년 전 조회 1,549
16년 전 조회 2,292
16년 전 조회 4,526
16년 전 조회 3,562
16년 전 조회 2,592
16년 전 조회 4,351
16년 전 조회 3,216
16년 전 조회 1,368
16년 전 조회 1,387
16년 전 조회 2,048
16년 전 조회 1,894
16년 전 조회 2,575
16년 전 조회 2,243
16년 전 조회 1,383
16년 전 조회 4,395
16년 전 조회 1,490
16년 전 조회 1,794
16년 전 조회 2,219
16년 전 조회 3,853
16년 전 조회 2,746
16년 전 조회 1,505
16년 전 조회 4,026
16년 전 조회 1,406
16년 전 조회 1,590
16년 전 조회 1,256
16년 전 조회 1,731
16년 전 조회 1,630
16년 전 조회 1,642
16년 전 조회 1,434
16년 전 조회 2,188
16년 전 조회 1,828
16년 전 조회 1,983
16년 전 조회 2,193
16년 전 조회 1,481