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,091
16년 전 조회 2,246
16년 전 조회 1,836
16년 전 조회 2,041
16년 전 조회 2,550
16년 전 조회 1,631
16년 전 조회 2,561
16년 전 조회 1,894
16년 전 조회 2,000
16년 전 조회 1,656
16년 전 조회 2,354
16년 전 조회 1,662
16년 전 조회 2,094
16년 전 조회 2,280
16년 전 조회 1,359
16년 전 조회 1,427
16년 전 조회 2,072
16년 전 조회 5,502
16년 전 조회 1,787
16년 전 조회 2,312
16년 전 조회 2,503
16년 전 조회 1,671
16년 전 조회 1,443
16년 전 조회 2,375
16년 전 조회 5,096
16년 전 조회 2,361
16년 전 조회 3,023
16년 전 조회 1,889
16년 전 조회 3,753
16년 전 조회 4,598
16년 전 조회 3,240
16년 전 조회 2,496
16년 전 조회 2,584
16년 전 조회 2,826
16년 전 조회 2,335
16년 전 조회 5,705
16년 전 조회 3,526
16년 전 조회 1,516
16년 전 조회 1,853
16년 전 조회 5,216
16년 전 조회 2,471
16년 전 조회 3,554
16년 전 조회 2,826
16년 전 조회 1,705
16년 전 조회 5,532
16년 전 조회 2,649
16년 전 조회 6,133
16년 전 조회 2,086
16년 전 조회 4,162
16년 전 조회 3,183
16년 전 조회 2,368
16년 전 조회 2,389
16년 전 조회 4,556
16년 전 조회 3,434
16년 전 조회 2,971
16년 전 조회 3,115
16년 전 조회 2,224
16년 전 조회 1,915
16년 전 조회 1,837
16년 전 조회 1,538
16년 전 조회 1,826
16년 전 조회 2,047
16년 전 조회 1,741
16년 전 조회 4,996
16년 전 조회 3,996
16년 전 조회 1,934
16년 전 조회 1,684
16년 전 조회 2,430
16년 전 조회 4,698
16년 전 조회 3,689
16년 전 조회 2,738
16년 전 조회 4,475
16년 전 조회 3,343
16년 전 조회 1,499
16년 전 조회 1,520
16년 전 조회 2,186
16년 전 조회 2,034
16년 전 조회 2,751
16년 전 조회 2,368
16년 전 조회 1,517
16년 전 조회 4,543
16년 전 조회 1,630
16년 전 조회 1,936
16년 전 조회 2,351
16년 전 조회 4,014
16년 전 조회 2,915
16년 전 조회 1,621
16년 전 조회 4,192
16년 전 조회 1,544
16년 전 조회 1,721
16년 전 조회 1,388
16년 전 조회 1,854
16년 전 조회 1,755
16년 전 조회 1,772
16년 전 조회 1,560
16년 전 조회 2,325
16년 전 조회 1,944
16년 전 조회 2,117
16년 전 조회 2,325
16년 전 조회 1,620