Oracle 小案例
create database cstd;
use cstd;
/*1:建立学生表*/
create table student (
学号 char(3) primary key,
姓名 char(8),
性别 char(4),
年龄 int,
班级 char(5)
);
insert into student values('','曾华','男',19,'');
insert into student values('','匡明','男',20,'');
insert into student values('','王丽','女',20,'');
insert into student values('','李军','男',19,'');
insert into student values('','王芳','女',22,'');
insert into student values('','陆君','男',20,'');
/*2:建立教师表*/
create table teacher(
教师号 char(3) primary key,
姓名 char(8),
性别 char(4),
年龄 int ,
级别 char(12),
专业 char(16)
);
insert into teacher values('','李成','男',42,'副教授','计算机系');
insert into teacher values('','张旭','男',35,'讲师','电子工程');
insert into teacher values('','王萍','女',28,'助教','计算机系');
insert into teacher values('','刘冰','女',25,'助教','电子工程');
/*3:建立课程表*/
create table course (
课程号 char(5) primary key,
课程名 char(20),
教师号 char(3),
foreign key(教师号) references teacher(教师号)
);
insert into course values('3-105','计算机导论','');
insert into course values('3-245','操作系统','');
insert into course values('6-166','数字电路','');
insert into course values('9-888','高等数学','');
/*4:建立选课表*/
create table sc(
学号 char(3),
课程号 char(5),
primary key(学号,课程号),
成绩 int,
foreign key(学号) references student(学号),
foreign key(课程号) references course(课程号)
);
insert into sc values('','3-245',86);
insert into sc values('','3-245',75);
insert into sc values('','3-245',68);
insert into sc values('','3-105',92);
insert into sc values('','3-105',88);
insert into sc values('','3-105',76);
insert into sc values('','3-105',64);
insert into sc values('','3-105',91);
insert into sc values('','3-105',78);
insert into sc values('','6-166',85);
insert into sc values('','6-166',79);
insert into sc values('','6-166',81);
/*5:所有表内容*/
select * from student;
select * from course;
select * from teacher;
select * from sc; --1.查询选修课程'3-105'且成绩在60到80之间的所有记录。
--注释:用于指定某个范围使用between and,也可以使用and连接符;
select * from sc where 课程号='3-105' and 成绩 between 60 and 80; --2.查询成绩为85、86或88的记录。
select * from sc where 成绩 in (85,86,88); --3.查询'95031'班的学生人数。
select count(学号) "95031班的学生人数" from student where 班级=''; --4.查询最低分大于70,且最高分小于90的学号列。
select 学号,max(成绩),min(成绩) from sc
having max(成绩)<90 and min(成绩) > 70
group by 学号; --5.查询至少有5名学生选修并以3开头的课程的平均成绩。
select avg(成绩)as 平均成绩 from sc where 课程号 like '3%' group by 课程号
having count(课程号)>=5 --6.查询平均分大于80分的学生的成绩表
select * from sc where 学号 in(select 学号 from sc group by 学号 having avg(成绩) > 80); --7.查询'95033'班每个学生所选课程的平均分。
select 学号,avg(成绩) from sc
where 学号 in (select 学号 from student where 班级='')
group by 学号; --8.以选修 '3-105'为例,查询成绩高于'109'号同学的所有同学的记录。
select * from student where 学号 in (select 学号 from sc
where 课程号='3-105' and 成绩>(select 成绩 from sc
where 课程号='3-105' and 学号='')); --9.查询与学号为'108'的同学同岁的所有学生的学号、姓名和年龄。
select * from student
where 年龄=(select 年龄 from student where 学号='')
and 学号 <>'' --10.查询'张旭'教师任课的课程号,选修其课程学生的学号和成绩。
select 学号,成绩 from sc where 课程号 in(select 课程号 from course
where 教师号 in (select 教师号 from teacher where 姓名 ='张旭'));
-- 另一种方式
select teacher.姓名 as 教师姓名,course.课程号,student.姓名 as 学生姓名,student.学号,成绩
from teacher inner join(course inner join(sc inner join student on student.学号=sc.学号)
on course.课程号=sc.课程号)on course.教师号=teacher.教师号 where teacher.姓名='张旭'; --11.查询选修其课程的学生人数多于5人的教师姓名。
select 教师号,姓名 from teacher
where 教师号 in (select 教师号 from course
where 课程号 in (select 课程号 from sc
having count(学号) > 5
group by 课程号)); --13.查询选修编号为'3-105'课程
--且成绩至少高于选修编号为'3-245'课程的同学
--的课程号、学号 、成绩并按成绩从高到低次序排列。
select 课程号,学号,成绩 from sc where 课程号 = '3-105'
and 成绩 > (select min(成绩) from sc where 课程号 = '3-245')
order by 成绩 desc;
--第二种方法
select 课程号,学号,成绩 from sc where 课程号 = '3-105'
and 成绩 > any(select 成绩 from sc where 课程号 = '3-245')
order by 成绩 desc; --14.查询选修编号为'3-105'课程
--且成绩高于选修编号为'3-245'课程的同学的课程号、学号 、成绩。
select 课程号,学号,成绩 from sc where 课程号 = '3-105'
and 成绩 > (select max(成绩) from sc where 课程号 = '3-245');
--第二种方法
select 课程号,学号,成绩 from sc where 课程号 = '3-105'
and 成绩 > all(select 成绩 from sc where 课程号 = '3-245')
order by 成绩 desc; --15.列出所有教师和同学的姓名 、性别 、年龄。
select student.姓名 as 学生姓名,student.性别 as 学生性别,student.年龄 as 学生年龄,
teacher.姓名 as 教师姓名,teacher.性别 as 教师性别,teacher.年龄 as 教师年龄 from
student inner join(sc inner join (course inner join teacher on course.教师号=teacher.教师号)
on sc.课程号=course.课程号)on student.学号=sc.学号; --16.查询成绩比'3-105'课程的平均成绩低的学生的成绩表。
select * from sc where 成绩<
(select avg(成绩) from sc where 课程号='3-105')and 课程号='3-105'; --17.查询成绩比该课程平均成绩低的学生的成绩表。
select * from sc where 成绩<any
(select avg(成绩) from sc group by 课程号)order by 课程号 asc; --18.列出所有任课教师的姓名和专业。
select teacher.姓名 as 教师姓名,专业 from teacher where 教师号 in
(select 教师号 from course where 课程号 in(select 课程号 from sc group by 课程号)); --19.列出所有未讲课教师的姓名和专业。
select teacher.姓名 as 教师姓名,专业 from teacher where 教师号 not in(select 教师号 from course
where 课程号 in(select 课程号 from sc group by 课程号)); --20.列出至少有2名男生的班号。
select 班级 as 班号 from student where 性别='男' having count(*)>=2 group by 班级; --21.查询不姓'王'的学生记录。
select * from student minus
select * from student where 姓名 like '王%';
-- 第二种方法
select * from student where 姓名 not like '王%';
-- 第三种方法
select * from student where 姓名 not in
(select 姓名 from student where 姓名 like '王%'); --22.查询每门课最高分的学生的学号、课程号、成绩。
select 学号,课程号 ,成绩 from sc where 成绩
in (select max(成绩) from sc group by 课程号); --23.查询与'李军'同性别并同班的同学名字。
-- 不包括'李军'本人
select 姓名,性别 from student
where 性别 = (select 性别 from student where 姓名='李军')
and 班级 = (select 班级 from student where 姓名='李军')
and 姓名<>'李军'; --24.查询'男'教师及其所上的课程。
select 姓名 as 教师名,课程名 as 课程 from teacher inner join
course on teacher.教师号=course.教师号 where 性别='男'; --25.查询选修'计算机导论'课程的'男'同学的成绩表。
select * from sc where 学号
in (select 学号 from student where 性别='男')
and 课程号=(select 课程号 from course where 课程名='计算机导论'); --第二种表达
select sc.学号,student.姓名 as 学生姓名,
student.性别 as 学生性别,sc.课程号,sc.成绩,course.课程名 from student
inner
join(sc inner join course on sc.课程号=course.课程号) on student.学号=sc.学号
where 性别='男' and 课程名='计算机导论';
Oracle 小案例的更多相关文章
- Oracle定时任务小案例
需求简述 一个数据表中包含此数据的录入时间,此数据的初始状态是有效,五天后系统自动置该数据的状态为无效. 方案 写一个存储过程,用于更新字段(改状态): 写一个job,用于定时执行存储过程: 方案逻辑 ...
- Eclipse使用JDBC小案例
JDBC(Java Database Connectivity:Java访问数据库的解决方案)定义一套标准接口,即访问数据库的通用API,不同数据库厂商根据各自数据的特点去实现这些接口. JDBC是J ...
- Oracle备份与恢复案例
注:以下内容来自<Oracle备份与恢复案例.doc>文档. Oracle备份与恢复案例 By Piner 一. 理解什么是数据库恢复 当我们使用一个数据库时,总希望数据库的内容是可靠的. ...
- 机械表小案例之transform的应用
这个小案例主要是对transform的应用. 时钟的3个表针分别是3个png图片,通过setInterval来让图片转动.时,分,秒的转动角度分别是30,6,6度. 首先,通过new Date函数获取 ...
- shell讲解-小案例
shell讲解-小案例 一.文件拷贝输出检查 下面测试文件拷贝是否正常,如果cp命令并没有拷贝文件myfile到myfile.bak,则打印错误信息.注意错误信息中basename $0打印脚本名.如 ...
- [jQuery学习系列六]6-jQuery实际操作小案例
前言最后在这里po上jQuery的几个小案例. Jquery例子1_占位符使用需求: 点击第一个按钮后 自动去check 后面是否有按钮没有选中, 如有则提示错误消息. <html> &l ...
- 02SpringMvc_springmvc快速入门小案例(XML版本)
这篇文章中,我们要写一个入门案例,去整体了解整个SpringMVC. 先给出整个项目的结构图:
- React.js入门小案例
<!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> <title&g ...
- SqlDependency缓存数据库表小案例
SqlDependency的简介: SqlDependency是outputcache网页缓存的一个参数,它的作用是指定缓存失效的数据库依赖项,可以具体到数据库和表. SqlDependency能解决 ...
随机推荐
- BZOJ 1925[Sdoi2010]地精部落 题解
题目大意: 1~n的排列中,要任意一个数要么比它左右的数都大或小,求所有的方案数. 思路: 主要思路:离散. 三个引理: ①在n->n-1的转化过程中,我们删除了一个点后,我们可以将n-1个点视 ...
- 【BZOJ1968】【AHoi2005】COMMON约数研究
Description Input 只有一行一个整数 N(0 < N < 1000000). Output 只有一行输出,为整数M,即f(1)到f(N)的累加和. Sample Input ...
- qt编译常见错误
一.fatal error: QWidget: 没有那个文件或目录 类似于找不到文件目录的,在.pro文件中添加 QT +=\ widgets 类似就可以编译通过
- IOS 登陆判断问题
有一个登陆界面,还有一个包含多个选项卡的界面在ViewController.m中登陆按钮的代码如下 UIViewController *controller=[[Tabbarcontroller al ...
- Oracle connect by 树查询之二
先用scott用户下的emp表做实验.emp表有个字段,一个是empno(员工编号),另一个是mgr(上级经理编号)下面是表中所有数据 1 select * from emp start with e ...
- C#多线程操作界面控件的解决方案(转)
C#中利用委托实现多线程跨线程操作 - 张小鱼 2010-10-22 08:38 在使用VS2005的时候,如果你从非创建这个控件的线程中访问这个控件或者操作这个控件的话就会抛出这个异常.这是微软为了 ...
- BFS 骑士的移动
骑士的移动 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=83498#problem/E 题目: Description A f ...
- iOS音频AAC视频H264编码 推流最佳方案
iOS音频AAC视频H264编码 推流最佳方案 项目都是个人的调研与实验,可能很多不好或者不对的地方请多包涵. 1 功能概况 * 实现音视频的数据的采集 * 实现音视频数据的编码,视频编码成 ...
- hdu杭电1671 / poj3630 字典树
传送门 题意:输入n串数字 找出是否有存在串的前缀与另一个串相同 如果存在 输出NO否则输出YES 思路:用字典树解决 标记字典树总串的结尾 查找出一个串内部是否有被标记的节点 如果有那么说明存在前缀 ...
- ado.net 完整修改删除,攻击防攻击
完整修改和删除:当你输入了要删除的用户名,先提示有没有此条数据 先查 后删/后改------------ using System; using System.Collections.Generic; ...