oracle练习
    使用的工具还是Pl/SQL 先添加以下表~
SQL代码
/    
--学生(学号,姓名,性别,年龄,班级代号)       
create table s(    
  s_id char(4),    
  s_name varchar2(20),    
  sex char(1),    
  age number(3),    
  class_id char(4)    
);    
--课程(课程号,课程名称,学分数,教师代号)    
create table c(    
  c_id char(4),    
  c_name varchar2(20),    
  c_xf number,    
  t_id char(4)    
);    
--学生选课(学号,课程号,成绩,考试时间)    
create table sc(    
  s_id char(4),    
  c_id char(4),    
  grade number(3),    
  g_date date   
);    
--教师(教师代号,姓名)    
create table t(    
  t_id char(4),    
  t_name varchar(20)    
);    
end;       
begin   
   delete from s;    
   delete from c;    
   delete from sc;    
   delete from t;    
   insert into s values('s001','yanming','1',30,'cls1');    
   insert into s values('s002','albert','1',30,'cls1');    
   insert into s values('s003','jack','1',23,'cls2');    
   insert into s values('s004','rose','0',24,'cls2');    
   insert into c values('c001','java',100,'t001');    
   insert into c values('c002','c',100,'t002');    
   insert into c values('c003','oracle',100,'t003');    
   insert into c values('c004','sql server',100,'t001');    
   insert into sc values('s001','c001',92,to_date('2009-02-10','YYYY-MM-DD'));    
   insert into sc values('s001','c002',91,to_date('2009-02-10','YYYY-MM-DD'));    
   insert into sc values('s001','c003',99,'12-2月-200');    
   insert into sc values('s002','c001',50,'10-2月-2009');    
   insert into sc values('s002','c002',58,'10-2月-2009');    
   insert into sc values('s003','c001',92,'15-2月-200');    
   insert into sc values('s003','c002',52,'15-2月-200');    
   insert into t values('t001','yang');    
   insert into t values('t002','liu');    
   insert into t values('t003','wang');    
end;    
/   
问题~
--(1) 找出男性学生的姓名
--(1.1) 统计出每个班级男生女生的人数
--(2) 找出不是'cls1'班的学生
-- (3) 查询“wang”老师所教课程的课程名称和学分
--(4) 检索出选修了课程代号为“java”和“c”课程的学生
--(5) 查询至少选修了一门“wang”老师的课程的学生姓名
--(6) 求选修了课程名为“java”的所有学生的学号和姓名
--(7) 找出学生代号为“s001”和“s002”两个学生都选修了的课程
--(8) 检索出没有被任何学生选修的课程
--(9) 求出每个学生的成绩的平均分和总分
--(10) 求至少三门以上课程成绩在90分以上的学生学号
--(10.1)查询出每门课都大于80分的学生姓名
--(11) 求出少于2个学生选修的课程
--(12) 求出有2门课程考试不及格的学生的姓名
--(13) 求出每个老师所教课程的成绩总数以及平均分
--(14) 求出每一个班级中每一门课程获得最高分的学生的学号
答案看下文~~~:
SQL代码
--(1) 找出男性学生的姓名     
select * from s where sex = '1';       
--(1.1) 统计出每个班级男生女生的人数