일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 원형그래프
- 라우터
- Oracle
- sql
- 리눅스
- 네트워크관리사
- Cisco
- 정보처리기사
- w3school
- 이것이 자바다
- ospf
- Java
- jsp
- NCS
- 오라클
- php
- html
- jsp연결
- VLAN
- 정처기필기
- 자바
- 네트워크
- javaee
- cisco packet
- 참조타입
- autoset
- rinux
- ciscopacket
- 버추얼머신
- 데이터베이스
- Today
- Total
기록해! 정리해!
3- 예제2 (join) 본문
drop table enrol;
drop table student;
drop table course;
create table student(
sno varchar2(3) ,
sname nvarchar2(10),
year varchar2(10),
dept nvarchar2(10) ,
constraint student_sno_pk primary key(sno));
create table course(
cno varchar2(5) primary key,
cname nvarchar2(10),
credit varchar2(3),
dept nvarchar2(10),
prname nvarchar2(10));
create table enrol(
sno varchar2(3) ,
cno varchar2(5) ,
grade varchar2(3),
midterm int,
final int ,
constraint enrol_sno_fk foreign key(sno) references student(sno),
constraint enrol_cno_fk foreign key(cno) references course(cno),
constraint enrol_combo_pk primary key(sno, cno));
insert into student(sno,sname,year,dept)
values('100','나연묵','4','컴퓨터');
insert into student(sno,sname,year,dept)
values('200','이찬영','3','전기');
insert into student(sno,sname,year,dept)
values('300','정기태','1','컴퓨터');
insert into student(sno,sname,year,dept)
values('400','송병호','4','컴퓨터');
insert into student(sno,sname,year,dept)
values('500','박종화','2','산공');
insert into course(cno,cname,credit,dept,prname)
values('C123','프로그래밍','3','컴퓨터','김성기');
insert into course(cno,cname,credit,dept,prname)
values('C312','자료구조','3','컴퓨터','황수찬');
insert into course(cno,cname,credit,dept,prname)
values('C324','화일처리','3','컴퓨터','이규철');
insert into course(cno,cname,credit,dept,prname)
values('C413','데이터베이스','3','컴퓨터','이성호');
insert into course(cno,cname,credit,dept,prname)
values('E412','반도체','3','전자','홍봉희');
insert into enrol(sno,cno,grade,midterm,final)
values('100','C413','A',90,95);
insert into enrol(sno,cno,grade,midterm,final)
values('100','E412','A',95,95);
insert into enrol(sno,cno,grade,midterm,final)
values('200','C123','B',85,80);
insert into enrol(sno,cno,grade,midterm,final)
values('300','C312','A',90,95);
insert into enrol(sno,cno,grade,midterm,final)
values('300','C324','C',75,75);
insert into enrol(sno,cno,grade,midterm,final)
values('300','C413','A',95,90);
insert into enrol(sno,cno,grade,midterm,final)
values('400','C312','A',90,95);
insert into enrol(sno,cno,grade,midterm,final)
values('400','C324','A',95,90);
insert into enrol(sno,cno,grade,midterm,final)
values('400','C413','B',80,85);
insert into enrol(sno,cno,grade,midterm,final)
values('400','E412','C',65,75);
insert into enrol(sno,cno,grade,midterm,final)
values('500','C312','B',85,80);
insert into enrol(sno,cno,grade,midterm,final)
values('400','C123','A',90,90);
select * from student;
select * from course;
select * from enrol;
1.나연묵 학생의 학번,이름,학년,중간,기말 성적을 나타내시오.
select student.sno, sname, year, midterm, final --내가 나타내고 싶은 것
from student
join enrol
on student.sno=enrol.sno
where sname='나연묵';
--TSQL로 join 없이 써보기
select s.sno, sname, year, midterm, final
from student s, enrol e
where s.sno=e.sno and sname='나연묵';
2.학번이 400번인 학생의 이름과 학과, 성적(grade)을 나타내시오. -별칭사용
select sname, dept, grade
from student s
join enrol e
on s.sno=e.sno
where s.sno='400';
3.컴퓨터과 학생과 전기과 학생의 이름과 학번, 성적(grade)을 나타내시오.
select sname, student.sno, grade
from student
join enrol
on student.sno=enrol.sno
where dept='컴퓨터' or dept='전기';
--and 사용X
4. 중간고사 성적이 90점 이상인 학생의 이름과 과목코드번호 중간고사 성적을 나타내시오.
select sname, cno, midterm
from student s
join enrol e
on s.sno=e.sno
where midterm>=90;
5. 3학년 4학년 학생의 이름과 과목코드,성적을 나타내시오
select sname, cno, midterm, final
from student s
join enrol e
on s.sno=e.sno
where year='3' or year='4';
--where year in(3,4);
6. 자료구조를 수강한 학생의 학번과 성적을 나타내시오.
select s.sno, midterm, final
from student s
join enrol e
on s.sno=e.sno
join course c
on e.cno=c.cno
where cname='자료구조';
7.성적이 A인 학생의 학번과 과목이름을 나타내시오. --sno는 enrol에도 있기 때문에 굳이 student를 join할 필요X
select sno, cname
from enrol e
join course c
on c.cno=e.cno
where grade='A';
--select에 grade 넣어서 한번 확인해주기
--값에 대해서는 대소문자 구분하기때문에 'a'넣으면 안나옴
8.이성호 교수가 가르친 과목을 수강한 학생의 학번과 성적을 나타내시오.
select sno, grade
from enrol e
join course c
on c.cno=e.cno
where prname='이성호';
--select에 prname 넣어서 한번 확인해주기