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) 统计出每个班级男生女生的人数