SQL语句题
SQL语句题
Student(Sno,Sname,Sage,Ssex)注释:学生表(学号,姓名,性别年龄,性别)
Course(Cno,Cname,Tno) 注释:课程表(课程号,课程名称,教师编号)
SC(Sno,Cno,score) 注释:成绩表(学号,课程号,成绩)
Teacher(Tno,Tname)注释:教师表(教师编号,教师名)
drop sequence s_student;
create sequence s_student;
drop table student cascade constraint purge;
create table Student(
Sno number primary key,
Sname varchar(30),
Sage number(3),
Ssex char(1)
);
insert into Student values(s_student.nextval,'张三1',21,'m');
insert into Student values(s_student.nextval,'张三2',22,'m');
insert into Student values(s_student.nextval,'张三3',23,'w');
insert into Student values(s_student.nextval,'张三4',24,'m');
commit;
drop sequence s_teacher;
create sequence s_teacher;
drop table teacher cascade constraint purge;
create table Teacher(
Tno number primary key,
Tname varchar(30)
);
insert into teacher values(s_teacher.nextval,'里老师1');
insert into teacher values(s_teacher.nextval,'张三');
insert into teacher values(s_teacher.nextval,'里老师3');
insert into teacher values(s_teacher.nextval,'里老师4');
commit;
成绩
drop table sc cascade constraint purge;
create table SC(
Sno number constraint sc_sno_fk references student(sno),
Cno number constraint sc_cno_fk references course(cno),
score number,
constraint sc_sno_cno_pk primary key(sno,cno)
) ;
insert into sc values(1,2,58);
insert into sc values(2,4,21);
insert into sc values(3,3,76);
insert into sc values(4,1,50);
insert into sc values(2,1,66);
insert into sc values(1,3,20);
insert into sc values(2,2,30);
insert into sc values(3,2,50);
insert into sc values(4,4,55);
commit;
课程
drop sequence s_course;
create sequence s_course;
drop table course cascade constraint purge;
create table Course(
Cno number primary key,
Cname varchar(30),
Tno number constraint course_tno_fk references teacher(tno)
);
insert into course values(s_course.nextval,'java',1);
insert into course values(s_course.nextval,'javascript',2);
insert into course values(s_course.nextval,'jdbc',3);
insert into course values(s_course.nextval,'hibernate',4);
commit;
1、查询每个学生的学号,姓名,所修课程及成绩;
select * from student st join sc s on st.sno=s.sno join course co on co.cno=s.cno;
2、查询学过“001”或者学过编号“002”课程的同学的学号、姓名;
非关联子查询
select * from student where sno in (select sno from course where cno=2 or cno=1);
关联子查询
select * from student s where exist (select 1 from course c where s.sno=c.sno and (cno=1 or cno=2));
3、将课程号为“002”的授课老师改为“张三”;
update course set tno=(select tno from teacher where tname='张三') where cno=4;
4、向SC表中插入一条记录,学号001,课程号003,成绩80;
delete from sc where sno=2 and cno=1;
5、删除“002”同学的“001”课程的成绩;
delete from sc where cno=1 and sno=4;
6、查询不及格的课程,并按课程号从大到小排列;
select score , cno from sc where score<60 order by cno desc;
7、查询两门以上不及格课程的同学的学号及其平均成绩;
select sno , avg(score) from sc
where score<60 group by sno having count(sno)>=2;
8、查询姓“李”的老师的姓名及授课情况;
select * from teacher t join course c on t.tno=c.tno where tname like '张%';
9、统计每门课程的学生选修人数(超过10人的课程才统计),要求输出课程号和选修人数查询结果按人数降序排序,若人数相同,按课程号升序排序;
select cno,count(cno) ,max(cname)
from(
select c.cno ,c.cname from sc s
join course c on s.cno=c.cno
)
group by cno
having count(cno)>1
order by cno desc;
10、统计列印各科成绩,各分数段人数:课程ID,课程名称[100-85],[85-70],[70-60],[<60]
select cname||'[85-100]' name,score,c.cno
from sc s join course c on s.cno=c.cno where score between 85 and 100
union
select cname||'[70-85]' name,score,c.cno
from sc s join course c on s.cno=c.cno where score between 70 and 85
union
select cname||'[60-70]' name,score,c.cno
from sc s join course c on s.cno=c.cno where score between 60 and 70
union
select cname||'[<60]' name,score,c.cno
from sc s join course c on s.cno=c.cno where score<60
SQL语句题的更多相关文章
- SQL语句题库
一. 填空题 Not Only SQL数据库 泛指 非关系型数据库 . SYS和SYSTEM用户都是Oracle 的系统用户,它们都使用SYSTEM表空间,其中 sys 拥有更大的权限. O ...
- 50道 Sql语句题
Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,score) 成绩表 Teacher(T#,Tname) 教师表 ...
- sql语句练习50题(Mysql版-详加注释)
表名和字段 1.学生表 Student(s_id,s_name,s_birth,s_sex) --学生编号,学生姓名, 出生年月,学生性别 2.课程表 Course(c_id, ...
- SQL语句50题
-- 一.创建教学系统的数据库,表,以及数据 --student(sno,sname,sage,ssex) 学生表--course(cno,cname,tno) 课程表--sc(sno,cno,sco ...
- sql语句练习50题(Mysql版)
表名和字段–1.学生表Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别–2.课程表Course(c_id,c_name,t_id) – ...
- 经典SQL语句基础50题
很全面的sql语句大全.都是很基础性的,今天特意整理了下.大家互相学习.大家有好的都可以分享出来, 分享也是一种快乐. --创建数据库 create database SQL50 --打开SQL50 ...
- -sql语句练习50题(Mysql学习练习版)
–1.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –2.课程表 Course(c_id,c_name,t_id) – –课 ...
- sql语句练习50题(Mysql版) 围观
表名和字段 –.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –.课程表 Course(c_id,c_name,t_id) ...
- MySQL经典练习题及答案,常用SQL语句练习50题
表名和字段 –1.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –2.课程表 Course(c_id,c_name,t_id ...
随机推荐
- TensorFlow object detection API
cloud执行:https://github.com/tensorflow/models/blob/master/research/object_detection/g3doc/running_pet ...
- Eclipse:An error has occurred. See error log for more details. java.lang.NullPointerException
问题描述 在使用 Eclipse Clean 项目时报错:An error has occurred. See error log for more details. java.lang.Null ...
- spring-cloud-eureka服务注册与发现
Eureka是Netflix开发的服务发现框架,本身是一个基于REST的服务,主要用于定位运行在AWS域中的中间层服务,以达到负载均衡和中间层服务故障转移的目的.SpringCloud将它集成在其子项 ...
- Zabbix (三)
一.zabbix支持的主要监控方式: zabbix主要Agent,Trapper,SNMP,JMX,IPMI这几种监控方式,本文章主要通过监控理论和实际操作测试等方式来简单介绍这几种方式的监控原理和优 ...
- Java堆和优先队列
普通队列:先进先出,后进后出 优先队列:出队顺序和入队顺序无关,和优先级相关. 堆中某个节点的值总是不对于其父节点的值,最大堆. public class Array<E> { priva ...
- asp:GridView控件使用FindControl方法获取控件的问题
一.使用带cells的指定列 e.Item.Cells[1].Controls[1]只指定第二列的第二个控件 二.不使用带cells的指定类e.Item.FindControl("ID&qu ...
- SQL反模式学习笔记5 外键约束【不用钥匙的入口】
目标:简化数据库架构 一些开发人员不推荐使用引用完整性约束,可能不使用外键的原因有一下几点: 1.数据更新有可能和约束冲突: 2.当前的数据库设计如此灵活,以至于不支持引用完整性约束: 3.数据库为外 ...
- web.xml中Servlet3.1版本的头信息格式
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http:// ...
- 部分手机浏览器存在将ajax请求当成广告过滤的情况,及解决方案
我们发现h5页面在某些浏览器请求不到数据,经过排查,是浏览器的广告拦截模块搞的鬼. 通过删减参数,发现adtype和adnum参数去掉后,接口可以正常请求,开始以为是官方拦截关键词带有ad的参数,后来 ...
- Android进阶:五、RxJava2源码解析 2
上一篇文章Android进阶:四.RxJava2 源码解析 1里我们讲到Rxjava2 从创建一个事件到事件被观察的过程原理,这篇文章我们讲Rxjava2中链式调用的原理.本文不讲用法,仍然需要读者熟 ...