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 부터는 바뀐게 많아서..
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
15년 전 조회 2,895
15년 전 조회 2,082
15년 전 조회 1,659
15년 전 조회 1,895
15년 전 조회 2,376
15년 전 조회 1,459
15년 전 조회 2,393
15년 전 조회 1,726
15년 전 조회 1,822
15년 전 조회 1,477
15년 전 조회 2,167
15년 전 조회 1,497
15년 전 조회 1,912
15년 전 조회 2,105
16년 전 조회 1,180
16년 전 조회 1,240
16년 전 조회 1,886
16년 전 조회 5,328
16년 전 조회 1,631
16년 전 조회 2,139
16년 전 조회 2,340
16년 전 조회 1,488
16년 전 조회 1,297
16년 전 조회 2,212
16년 전 조회 4,926
16년 전 조회 2,201
16년 전 조회 2,857
16년 전 조회 1,738
16년 전 조회 3,592
16년 전 조회 4,429
16년 전 조회 3,098
16년 전 조회 2,343
16년 전 조회 2,425
16년 전 조회 2,673
16년 전 조회 2,162
16년 전 조회 5,503
16년 전 조회 3,355
16년 전 조회 1,347
16년 전 조회 1,694
16년 전 조회 5,063
16년 전 조회 2,299
16년 전 조회 3,405
16년 전 조회 2,638
16년 전 조회 1,557
16년 전 조회 5,350
16년 전 조회 2,465
16년 전 조회 5,958
16년 전 조회 1,933
16년 전 조회 4,009
16년 전 조회 3,025
16년 전 조회 2,209
16년 전 조회 2,229
16년 전 조회 4,403
16년 전 조회 3,289
16년 전 조회 2,827
16년 전 조회 2,961
16년 전 조회 2,078
16년 전 조회 1,765
16년 전 조회 1,673
16년 전 조회 1,396
16년 전 조회 1,668
16년 전 조회 1,897
16년 전 조회 1,587
16년 전 조회 4,837
16년 전 조회 3,819
16년 전 조회 1,785
16년 전 조회 1,528
16년 전 조회 2,267
16년 전 조회 4,511
16년 전 조회 3,537
16년 전 조회 2,574
16년 전 조회 4,332
16년 전 조회 3,201
16년 전 조회 1,349
16년 전 조회 1,367
16년 전 조회 2,031
16년 전 조회 1,878
16년 전 조회 2,554
16년 전 조회 2,225
16년 전 조회 1,357
16년 전 조회 4,376
16년 전 조회 1,472
16년 전 조회 1,776
16년 전 조회 2,198
16년 전 조회 3,832
16년 전 조회 2,729
16년 전 조회 1,484
16년 전 조회 4,007
16년 전 조회 1,390
16년 전 조회 1,573
16년 전 조회 1,237
16년 전 조회 1,711
16년 전 조회 1,609
16년 전 조회 1,626
16년 전 조회 1,417
16년 전 조회 2,170
16년 전 조회 1,811
16년 전 조회 1,965
16년 전 조회 2,176
16년 전 조회 1,463
🐛 버그신고