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,488
16년 전 조회 2,645
16년 전 조회 2,242
16년 전 조회 2,432
16년 전 조회 2,934
16년 전 조회 2,033
16년 전 조회 2,956
16년 전 조회 2,277
16년 전 조회 2,405
16년 전 조회 2,027
16년 전 조회 2,738
16년 전 조회 2,065
16년 전 조회 2,484
16년 전 조회 2,665
16년 전 조회 1,736
16년 전 조회 1,796
16년 전 조회 2,465
16년 전 조회 5,875
16년 전 조회 2,193
16년 전 조회 2,722
16년 전 조회 2,904
16년 전 조회 2,054
16년 전 조회 1,837
16년 전 조회 2,765
16년 전 조회 5,480
16년 전 조회 2,758
16년 전 조회 3,414
16년 전 조회 2,269
16년 전 조회 4,174
16년 전 조회 4,963
16년 전 조회 3,606
16년 전 조회 2,859
16년 전 조회 2,978
16년 전 조회 3,185
16년 전 조회 2,709
16년 전 조회 6,066
16년 전 조회 3,890
16년 전 조회 1,878
16년 전 조회 2,210
16년 전 조회 5,572
16년 전 조회 2,818
16년 전 조회 3,902
16년 전 조회 3,178
16년 전 조회 2,075
16년 전 조회 5,895
16년 전 조회 2,998
16년 전 조회 6,486
16년 전 조회 2,476
16년 전 조회 4,509
16년 전 조회 3,523
16년 전 조회 2,706
16년 전 조회 2,733
16년 전 조회 4,863
16년 전 조회 3,799
16년 전 조회 3,319
16년 전 조회 3,475
16년 전 조회 2,595
16년 전 조회 2,262
16년 전 조회 2,185
16년 전 조회 1,904
16년 전 조회 2,182
16년 전 조회 2,378
16년 전 조회 2,094
16년 전 조회 5,336
16년 전 조회 4,334
16년 전 조회 2,279
16년 전 조회 2,027
16년 전 조회 2,786
16년 전 조회 5,029
16년 전 조회 4,045
16년 전 조회 3,080
16년 전 조회 4,822
16년 전 조회 3,673
16년 전 조회 1,823
16년 전 조회 1,851
16년 전 조회 2,525
16년 전 조회 2,354
16년 전 조회 3,073
16년 전 조회 2,680
16년 전 조회 1,826
16년 전 조회 4,877
16년 전 조회 1,953
16년 전 조회 2,261
16년 전 조회 2,697
16년 전 조회 4,341
16년 전 조회 3,241
16년 전 조회 1,956
16년 전 조회 4,498
16년 전 조회 1,861
16년 전 조회 2,041
16년 전 조회 1,711
16년 전 조회 2,182
16년 전 조회 2,107
16년 전 조회 2,097
16년 전 조회 1,873
16년 전 조회 2,634
16년 전 조회 2,270
16년 전 조회 2,429
16년 전 조회 2,657
16년 전 조회 1,924