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,021
15년 전 조회 2,185
16년 전 조회 1,782
16년 전 조회 1,994
16년 전 조회 2,488
16년 전 조회 1,568
16년 전 조회 2,502
16년 전 조회 1,828
16년 전 조회 1,940
16년 전 조회 1,589
16년 전 조회 2,289
16년 전 조회 1,600
16년 전 조회 2,028
16년 전 조회 2,213
16년 전 조회 1,281
16년 전 조회 1,347
16년 전 조회 2,007
16년 전 조회 5,432
16년 전 조회 1,731
16년 전 조회 2,256
16년 전 조회 2,451
16년 전 조회 1,604
16년 전 조회 1,395
16년 전 조회 2,327
16년 전 조회 5,036
16년 전 조회 2,308
16년 전 조회 2,970
16년 전 조회 1,843
16년 전 조회 3,694
16년 전 조회 4,535
16년 전 조회 3,188
16년 전 조회 2,444
16년 전 조회 2,541
16년 전 조회 2,773
16년 전 조회 2,272
16년 전 조회 5,624
16년 전 조회 3,466
16년 전 조회 1,452
16년 전 조회 1,810
16년 전 조회 5,168
16년 전 조회 2,413
16년 전 조회 3,501
16년 전 조회 2,756
16년 전 조회 1,659
16년 전 조회 5,465
16년 전 조회 2,568
16년 전 조회 6,066
16년 전 조회 2,036
16년 전 조회 4,114
16년 전 조회 3,132
16년 전 조회 2,310
16년 전 조회 2,329
16년 전 조회 4,482
16년 전 조회 3,386
16년 전 조회 2,923
16년 전 조회 3,064
16년 전 조회 2,187
16년 전 조회 1,868
16년 전 조회 1,786
16년 전 조회 1,502
16년 전 조회 1,769
16년 전 조회 1,998
16년 전 조회 1,695
16년 전 조회 4,933
16년 전 조회 3,931
16년 전 조회 1,889
16년 전 조회 1,640
16년 전 조회 2,373
16년 전 조회 4,617
16년 전 조회 3,637
16년 전 조회 2,683
16년 전 조회 4,422
16년 전 조회 3,291
16년 전 조회 1,457
16년 전 조회 1,473
16년 전 조회 2,146
16년 전 조회 1,982
16년 전 조회 2,671
16년 전 조회 2,326
16년 전 조회 1,464
16년 전 조회 4,485
16년 전 조회 1,579
16년 전 조회 1,880
16년 전 조회 2,299
16년 전 조회 3,946
16년 전 조회 2,844
16년 전 조회 1,581
16년 전 조회 4,123
16년 전 조회 1,489
16년 전 조회 1,674
16년 전 조회 1,347
16년 전 조회 1,808
16년 전 조회 1,717
16년 전 조회 1,723
16년 전 조회 1,509
16년 전 조회 2,276
16년 전 조회 1,902
16년 전 조회 2,059
16년 전 조회 2,287
16년 전 조회 1,569