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 부터는 바뀐게 많아서..
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
16년 전 조회 3,496
16년 전 조회 2,653
16년 전 조회 2,254
16년 전 조회 2,440
16년 전 조회 2,955
16년 전 조회 2,043
16년 전 조회 2,963
16년 전 조회 2,289
16년 전 조회 2,415
16년 전 조회 2,035
16년 전 조회 2,747
16년 전 조회 2,070
16년 전 조회 2,493
16년 전 조회 2,671
16년 전 조회 1,743
16년 전 조회 1,806
16년 전 조회 2,469
16년 전 조회 5,890
16년 전 조회 2,203
16년 전 조회 2,730
16년 전 조회 2,911
16년 전 조회 2,062
16년 전 조회 1,849
16년 전 조회 2,777
16년 전 조회 5,491
16년 전 조회 2,768
16년 전 조회 3,425
16년 전 조회 2,277
16년 전 조회 4,183
16년 전 조회 4,974
16년 전 조회 3,618
16년 전 조회 2,867
16년 전 조회 2,989
16년 전 조회 3,201
16년 전 조회 2,718
16년 전 조회 6,076
16년 전 조회 3,896
16년 전 조회 1,886
16년 전 조회 2,223
16년 전 조회 5,582
16년 전 조회 2,829
16년 전 조회 3,911
16년 전 조회 3,186
16년 전 조회 2,082
16년 전 조회 5,907
16년 전 조회 3,015
16년 전 조회 6,501
16년 전 조회 2,485
16년 전 조회 4,517
16년 전 조회 3,532
16년 전 조회 2,716
16년 전 조회 2,748
16년 전 조회 4,871
16년 전 조회 3,811
16년 전 조회 3,329
16년 전 조회 3,486
16년 전 조회 2,604
16년 전 조회 2,277
16년 전 조회 2,193
16년 전 조회 1,908
16년 전 조회 2,191
16년 전 조회 2,395
16년 전 조회 2,104
16년 전 조회 5,349
16년 전 조회 4,346
16년 전 조회 2,291
16년 전 조회 2,034
16년 전 조회 2,802
16년 전 조회 5,038
16년 전 조회 4,063
16년 전 조회 3,088
16년 전 조회 4,831
16년 전 조회 3,678
16년 전 조회 1,829
16년 전 조회 1,863
16년 전 조회 2,536
16년 전 조회 2,368
16년 전 조회 3,080
16년 전 조회 2,692
16년 전 조회 1,835
16년 전 조회 4,885
16년 전 조회 1,961
16년 전 조회 2,277
16년 전 조회 2,707
16년 전 조회 4,351
16년 전 조회 3,248
16년 전 조회 1,967
16년 전 조회 4,508
16년 전 조회 1,872
16년 전 조회 2,052
16년 전 조회 1,718
16년 전 조회 2,192
16년 전 조회 2,119
16년 전 조회 2,109
16년 전 조회 1,881
16년 전 조회 2,649
16년 전 조회 2,279
16년 전 조회 2,436
16년 전 조회 2,671
16년 전 조회 1,934