1.表结构

-- Create table 课程表
create table T_COURSE
(
  cno        VARCHAR2(20),
  cname      VARCHAR2(20),
  creatdate  CHAR(10),
  updatedate CHAR(10)
)
tablespace USERS
  pctfree 10
  initrans 1
  maxtrans 255
  storage
  (
    initial 64K
    next 1M
    minextents 1
    maxextents unlimited
  );

-- Create table 学生表
create table T_STUDENT
(
  sno   VARCHAR2(20),
  sname VARCHAR2(20),
  sage  NUMBER
)
tablespace USERS
  pctfree 10
  initrans 1
  maxtrans 255
  storage
  (
    initial 64K
    next 1M
    minextents 1
    maxextents unlimited
  );

-- Create table 学生与课程关联表
create table T_STUDENT_COURSE
(
  sno     VARCHAR2(64),
  cno     VARCHAR2(64),
  score   NUMBER(15,2),
  ischeat NUMBER
)
tablespace USERS
  pctfree 10
  initrans 1
  maxtrans 255
  storage
  (
    initial 64K
    next 1M
    minextents 1
    maxextents unlimited
  );

二:表数据

insert into T_STUDENT (SNO, SNAME, SAGE)
values ('s1001', 'JITION', 50);

insert into T_STUDENT (SNO, SNAME, SAGE)
values ('s1002', 'CQS', 13);

insert into T_STUDENT (SNO, SNAME, SAGE)
values ('s1003', 'CAO', 30);

insert into T_STUDENT (SNO, SNAME, SAGE)
values ('s1004', 'QI', 15);

insert into T_STUDENT (SNO, SNAME, SAGE)
values ('s1005', 'SHUN', 30);

--
insert into T_COURSE (CNO, CNAME, CREATDATE, UPDATEDATE)
values ('c1001', 'JAVA程序设计', null, null);

insert into T_COURSE (CNO, CNAME, CREATDATE, UPDATEDATE)
values ('c1002', '数学', null, null);

insert into T_COURSE (CNO, CNAME, CREATDATE, UPDATEDATE)
values ('c1003', '英语', null, null);

insert into T_COURSE (CNO, CNAME, CREATDATE, UPDATEDATE)
values ('c1004', 'SQL程序设计', null, null);

insert into T_COURSE (CNO, CNAME, CREATDATE, UPDATEDATE)
values ('c1005', '语文', null, null);

insert into T_COURSE (CNO, CNAME, CREATDATE, UPDATEDATE)
values ('c1006', 'JAVA算法', '2010-10-30', null);

insert into T_COURSE (CNO, CNAME, CREATDATE, UPDATEDATE)
values ('c1007', '算法设计', '2017-10-30', null);

insert into T_COURSE (CNO, CNAME, CREATDATE, UPDATEDATE)
values ('c1008', '物理', null, null);

--
insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1001', 'c1001', 36.00, 1);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1001', 'c1002', 72.00, 1);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1002', 'c1001', 100.00, 1);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1002', 'c1003', 0.00, 0);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1003', 'c1011', 0.00, 0);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1004', 'c1001', 90.00, 1);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1004', 'c1003', 80.00, 1);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1001', 'c1007', 0.00, 0);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1002', 'c1007', 90.00, 1);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1003', 'c1007', 85.00, 1);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1004', 'c1007', 0.00, 0);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1005', 'c1007', 96.00, 1);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1001', 'c1004', 80.00, 1);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1001', 'c1003', 80.00, 1);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1001', 'c1005', 90.00, 1);

insert into T_STUDENT_COURSE (SNO, CNO, SCORE, ISCHEAT)
values ('s1001', 'c1006', 80.00, 1);

3:问题及sql语句

--1.指定课程所有学员姓名和学号
select ts.sno,ts.sname,tc.cname from t_student_course tsc 
inner join T_COURSE tc on tc.cno=tsc.cno
inner join t_Student ts on ts.sno=tsc.sno
where tc.cname='JAVA程序设计'

--2.指定课程并且年龄大于20
select count(1) "求和" from t_student_course tsc 
inner join T_COURSE tc on tc.cno=tsc.cno
inner join t_Student ts on ts.sno=tsc.sno
where tc.cname='算法设计' and ts.sage>20

--3.查询选修课程超过5门的学生学号、姓名
      --方法一
select ts.sno,ts.sname from t_student_course tsc 
left join T_COURSE tc on tc.cno=tsc.cno
left join t_Student ts on ts.sno=tsc.sno
GROUP BY ts.sno ,ts.sname
having count(*)>5
       --方法二
select ts.sno,ts.sname from t_student ts
where ts.sno in(
select tsc.sno FROM t_student_course tsc
GROUP BY tsc.sno
having count(Distinct(tsc.cno))>5 
)

--4.修改t_student_course表中ISCheat为0的学生成绩更新为0
update t_student_course  tsc set tsc.score=0 where tsc.ischeat=0 

--5.将t_student_course表中ISCheat为0的学生从t_student表中删除
delete from t_student ts where ts.sno in( select tsc.sno from t_student_course  tsc where   tsc.ischeat=0 )

--6.查询所有课程分数小于60分且没有作弊的学生号,学生姓名,分数
select * from t_student_course tsc
left join t_student ts on tsc.sno=ts.sno
where tsc.score<60 and tsc.ischeat=1