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년 전 조회 3,023
15년 전 조회 2,191
16년 전 조회 1,787
16년 전 조회 1,996
16년 전 조회 2,490
16년 전 조회 1,573
16년 전 조회 2,506
16년 전 조회 1,831
16년 전 조회 1,944
16년 전 조회 1,594
16년 전 조회 2,291
16년 전 조회 1,605
16년 전 조회 2,029
16년 전 조회 2,219
16년 전 조회 1,294
16년 전 조회 1,352
16년 전 조회 2,013
16년 전 조회 5,438
16년 전 조회 1,738
16년 전 조회 2,257
16년 전 조회 2,453
16년 전 조회 1,608
16년 전 조회 1,399
16년 전 조회 2,328
16년 전 조회 5,041
16년 전 조회 2,309
16년 전 조회 2,971
16년 전 조회 1,845
16년 전 조회 3,699
16년 전 조회 4,542
16년 전 조회 3,190
16년 전 조회 2,451
16년 전 조회 2,544
16년 전 조회 2,777
16년 전 조회 2,275
16년 전 조회 5,628
16년 전 조회 3,471
16년 전 조회 1,456
16년 전 조회 1,811
16년 전 조회 5,170
16년 전 조회 2,417
16년 전 조회 3,503
16년 전 조회 2,765
16년 전 조회 1,660
16년 전 조회 5,467
16년 전 조회 2,574
16년 전 조회 6,070
16년 전 조회 2,041
16년 전 조회 4,115
16년 전 조회 3,138
16년 전 조회 2,311
16년 전 조회 2,333
16년 전 조회 4,488
16년 전 조회 3,391
16년 전 조회 2,925
16년 전 조회 3,071
16년 전 조회 2,189
16년 전 조회 1,871
16년 전 조회 1,790
16년 전 조회 1,504
16년 전 조회 1,775
16년 전 조회 2,001
16년 전 조회 1,699
16년 전 조회 4,937
16년 전 조회 3,942
16년 전 조회 1,893
16년 전 조회 1,642
16년 전 조회 2,378
16년 전 조회 4,624
16년 전 조회 3,640
16년 전 조회 2,686
16년 전 조회 4,426
16년 전 조회 3,295
16년 전 조회 1,457
16년 전 조회 1,477
16년 전 조회 2,147
16년 전 조회 1,984
16년 전 조회 2,678
16년 전 조회 2,329
16년 전 조회 1,471
16년 전 조회 4,491
16년 전 조회 1,585
16년 전 조회 1,884
16년 전 조회 2,303
16년 전 조회 3,955
16년 전 조회 2,853
16년 전 조회 1,586
16년 전 조회 4,131
16년 전 조회 1,494
16년 전 조회 1,676
16년 전 조회 1,348
16년 전 조회 1,811
16년 전 조회 1,722
16년 전 조회 1,727
16년 전 조회 1,512
16년 전 조회 2,276
16년 전 조회 1,905
16년 전 조회 2,062
16년 전 조회 2,288
16년 전 조회 1,573