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,501
16년 전 조회 2,659
16년 전 조회 2,257
16년 전 조회 2,446
16년 전 조회 2,958
16년 전 조회 2,047
16년 전 조회 2,970
16년 전 조회 2,293
16년 전 조회 2,418
16년 전 조회 2,044
16년 전 조회 2,754
16년 전 조회 2,071
16년 전 조회 2,498
16년 전 조회 2,677
16년 전 조회 1,748
16년 전 조회 1,811
16년 전 조회 2,474
16년 전 조회 5,896
16년 전 조회 2,205
16년 전 조회 2,732
16년 전 조회 2,913
16년 전 조회 2,070
16년 전 조회 1,854
16년 전 조회 2,779
16년 전 조회 5,496
16년 전 조회 2,773
16년 전 조회 3,428
16년 전 조회 2,286
16년 전 조회 4,184
16년 전 조회 4,978
16년 전 조회 3,623
16년 전 조회 2,870
16년 전 조회 2,995
16년 전 조회 3,208
16년 전 조회 2,726
16년 전 조회 6,079
16년 전 조회 3,900
16년 전 조회 1,889
16년 전 조회 2,227
16년 전 조회 5,589
16년 전 조회 2,835
16년 전 조회 3,918
16년 전 조회 3,192
16년 전 조회 2,091
16년 전 조회 5,915
16년 전 조회 3,021
16년 전 조회 6,505
16년 전 조회 2,486
16년 전 조회 4,521
16년 전 조회 3,535
16년 전 조회 2,719
16년 전 조회 2,753
16년 전 조회 4,876
16년 전 조회 3,815
16년 전 조회 3,338
16년 전 조회 3,495
16년 전 조회 2,611
16년 전 조회 2,282
16년 전 조회 2,194
16년 전 조회 1,909
16년 전 조회 2,195
16년 전 조회 2,397
16년 전 조회 2,108
16년 전 조회 5,357
16년 전 조회 4,347
16년 전 조회 2,296
16년 전 조회 2,039
16년 전 조회 2,809
16년 전 조회 5,046
16년 전 조회 4,065
16년 전 조회 3,092
16년 전 조회 4,837
16년 전 조회 3,682
16년 전 조회 1,836
16년 전 조회 1,868
16년 전 조회 2,542
16년 전 조회 2,376
16년 전 조회 3,083
16년 전 조회 2,696
16년 전 조회 1,839
16년 전 조회 4,887
16년 전 조회 1,975
16년 전 조회 2,283
16년 전 조회 2,710
16년 전 조회 4,357
16년 전 조회 3,253
16년 전 조회 1,971
16년 전 조회 4,511
16년 전 조회 1,873
16년 전 조회 2,057
16년 전 조회 1,723
16년 전 조회 2,198
16년 전 조회 2,122
16년 전 조회 2,112
16년 전 조회 1,887
16년 전 조회 2,654
16년 전 조회 2,282
16년 전 조회 2,443
16년 전 조회 2,675
16년 전 조회 1,939