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,284
16년 전 조회 2,449
16년 전 조회 2,037
16년 전 조회 2,240
16년 전 조회 2,742
16년 전 조회 1,809
16년 전 조회 2,745
16년 전 조회 2,065
16년 전 조회 2,202
16년 전 조회 1,849
16년 전 조회 2,542
16년 전 조회 1,862
16년 전 조회 2,283
16년 전 조회 2,436
16년 전 조회 1,537
16년 전 조회 1,600
16년 전 조회 2,251
16년 전 조회 5,670
16년 전 조회 1,974
16년 전 조회 2,499
16년 전 조회 2,690
16년 전 조회 1,852
16년 전 조회 1,626
16년 전 조회 2,559
16년 전 조회 5,277
16년 전 조회 2,549
16년 전 조회 3,210
16년 전 조회 2,074
16년 전 조회 3,947
16년 전 조회 4,780
16년 전 조회 3,417
16년 전 조회 2,658
16년 전 조회 2,767
16년 전 조회 2,996
16년 전 조회 2,517
16년 전 조회 5,874
16년 전 조회 3,696
16년 전 조회 1,685
16년 전 조회 2,031
16년 전 조회 5,391
16년 전 조회 2,654
16년 전 조회 3,717
16년 전 조회 3,005
16년 전 조회 1,877
16년 전 조회 5,705
16년 전 조회 2,813
16년 전 조회 6,293
16년 전 조회 2,269
16년 전 조회 4,321
16년 전 조회 3,344
16년 전 조회 2,531
16년 전 조회 2,539
16년 전 조회 4,693
16년 전 조회 3,611
16년 전 조회 3,138
16년 전 조회 3,281
16년 전 조회 2,409
16년 전 조회 2,062
16년 전 조회 1,995
16년 전 조회 1,702
16년 전 조회 2,006
16년 전 조회 2,207
16년 전 조회 1,906
16년 전 조회 5,152
16년 전 조회 4,157
16년 전 조회 2,089
16년 전 조회 1,861
16년 전 조회 2,583
16년 전 조회 4,854
16년 전 조회 3,857
16년 전 조회 2,894
16년 전 조회 4,625
16년 전 조회 3,498
16년 전 조회 1,657
16년 전 조회 1,689
16년 전 조회 2,342
16년 전 조회 2,191
16년 전 조회 2,909
16년 전 조회 2,523
16년 전 조회 1,661
16년 전 조회 4,699
16년 전 조회 1,788
16년 전 조회 2,086
16년 전 조회 2,509
16년 전 조회 4,174
16년 전 조회 3,066
16년 전 조회 1,786
16년 전 조회 4,340
16년 전 조회 1,702
16년 전 조회 1,871
16년 전 조회 1,553
16년 전 조회 2,013
16년 전 조회 1,927
16년 전 조회 1,931
16년 전 조회 1,718
16년 전 조회 2,472
16년 전 조회 2,095
16년 전 조회 2,269
16년 전 조회 2,496
16년 전 조회 1,772