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,308
16년 전 조회 2,465
16년 전 조회 2,061
16년 전 조회 2,262
16년 전 조회 2,762
16년 전 조회 1,831
16년 전 조회 2,761
16년 전 조회 2,080
16년 전 조회 2,217
16년 전 조회 1,863
16년 전 조회 2,565
16년 전 조회 1,880
16년 전 조회 2,300
16년 전 조회 2,456
16년 전 조회 1,556
16년 전 조회 1,620
16년 전 조회 2,272
16년 전 조회 5,688
16년 전 조회 1,999
16년 전 조회 2,514
16년 전 조회 2,709
16년 전 조회 1,870
16년 전 조회 1,644
16년 전 조회 2,581
16년 전 조회 5,297
16년 전 조회 2,568
16년 전 조회 3,224
16년 전 조회 2,087
16년 전 조회 3,970
16년 전 조회 4,792
16년 전 조회 3,431
16년 전 조회 2,678
16년 전 조회 2,786
16년 전 조회 3,011
16년 전 조회 2,538
16년 전 조회 5,887
16년 전 조회 3,714
16년 전 조회 1,698
16년 전 조회 2,041
16년 전 조회 5,402
16년 전 조회 2,667
16년 전 조회 3,731
16년 전 조회 3,015
16년 전 조회 1,897
16년 전 조회 5,711
16년 전 조회 2,831
16년 전 조회 6,317
16년 전 조회 2,284
16년 전 조회 4,338
16년 전 조회 3,365
16년 전 조회 2,549
16년 전 조회 2,565
16년 전 조회 4,704
16년 전 조회 3,627
16년 전 조회 3,156
16년 전 조회 3,298
16년 전 조회 2,425
16년 전 조회 2,080
16년 전 조회 2,014
16년 전 조회 1,716
16년 전 조회 2,020
16년 전 조회 2,223
16년 전 조회 1,924
16년 전 조회 5,171
16년 전 조회 4,170
16년 전 조회 2,101
16년 전 조회 1,879
16년 전 조회 2,601
16년 전 조회 4,867
16년 전 조회 3,877
16년 전 조회 2,912
16년 전 조회 4,644
16년 전 조회 3,511
16년 전 조회 1,669
16년 전 조회 1,699
16년 전 조회 2,356
16년 전 조회 2,204
16년 전 조회 2,925
16년 전 조회 2,542
16년 전 조회 1,674
16년 전 조회 4,713
16년 전 조회 1,799
16년 전 조회 2,102
16년 전 조회 2,530
16년 전 조회 4,190
16년 전 조회 3,083
16년 전 조회 1,807
16년 전 조회 4,357
16년 전 조회 1,719
16년 전 조회 1,889
16년 전 조회 1,570
16년 전 조회 2,031
16년 전 조회 1,947
16년 전 조회 1,948
16년 전 조회 1,728
16년 전 조회 2,491
16년 전 조회 2,110
16년 전 조회 2,285
16년 전 조회 2,512
16년 전 조회 1,782