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,422
16년 전 조회 2,592
16년 전 조회 2,187
16년 전 조회 2,386
16년 전 조회 2,886
16년 전 조회 1,979
16년 전 조회 2,897
16년 전 조회 2,226
16년 전 조회 2,345
16년 전 조회 1,972
16년 전 조회 2,691
16년 전 조회 2,001
16년 전 조회 2,425
16년 전 조회 2,597
16년 전 조회 1,671
16년 전 조회 1,734
16년 전 조회 2,405
16년 전 조회 5,817
16년 전 조회 2,134
16년 전 조회 2,655
16년 전 조회 2,837
16년 전 조회 1,999
16년 전 조회 1,787
16년 전 조회 2,707
16년 전 조회 5,419
16년 전 조회 2,694
16년 전 조회 3,349
16년 전 조회 2,217
16년 전 조회 4,098
16년 전 조회 4,897
16년 전 조회 3,546
16년 전 조회 2,799
16년 전 조회 2,915
16년 전 조회 3,131
16년 전 조회 2,643
16년 전 조회 5,996
16년 전 조회 3,820
16년 전 조회 1,821
16년 전 조회 2,148
16년 전 조회 5,518
16년 전 조회 2,769
16년 전 조회 3,847
16년 전 조회 3,124
16년 전 조회 2,023
16년 전 조회 5,839
16년 전 조회 2,937
16년 전 조회 6,429
16년 전 조회 2,407
16년 전 조회 4,460
16년 전 조회 3,463
16년 전 조회 2,658
16년 전 조회 2,683
16년 전 조회 4,814
16년 전 조회 3,747
16년 전 조회 3,271
16년 전 조회 3,426
16년 전 조회 2,539
16년 전 조회 2,210
16년 전 조회 2,134
16년 전 조회 1,841
16년 전 조회 2,125
16년 전 조회 2,335
16년 전 조회 2,038
16년 전 조회 5,287
16년 전 조회 4,284
16년 전 조회 2,233
16년 전 조회 1,978
16년 전 조회 2,730
16년 전 조회 4,981
16년 전 조회 3,986
16년 전 조회 3,018
16년 전 조회 4,767
16년 전 조회 3,615
16년 전 조회 1,773
16년 전 조회 1,804
16년 전 조회 2,477
16년 전 조회 2,317
16년 전 조회 3,032
16년 전 조회 2,645
16년 전 조회 1,786
16년 전 조회 4,826
16년 전 조회 1,906
16년 전 조회 2,212
16년 전 조회 2,648
16년 전 조회 4,294
16년 전 조회 3,195
16년 전 조회 1,912
16년 전 조회 4,464
16년 전 조회 1,818
16년 전 조회 2,003
16년 전 조회 1,668
16년 전 조회 2,147
16년 전 조회 2,065
16년 전 조회 2,049
16년 전 조회 1,831
16년 전 조회 2,593
16년 전 조회 2,231
16년 전 조회 2,391
16년 전 조회 2,619
16년 전 조회 1,885