Oracle数据库实现建表、查询方式
作者:manhoho
这篇文章主要介绍了Oracle数据库实现建表、查询方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
一. 创建三张表
1.学生信息表(stuInfo): 学号(主键), 姓名(不能为空), 性别(只能是男或女), 生日
` create table stuInfo( stuInfoID number primary key, stuInfoName varchar2(32) not null, stuInfoSex varchar2(32) not null check(stuInfoSex in('男','女')), stuInfoBrithday date ) /`
2.课程信息表(subInfo):编号(主键),课程名(不能为空)
create table subInfo( subInfoID number primary key, subInfoName varchar2(32) not null ) /
3.分数信息表(scoreInfo):编号(主键),学号(外键),课程号(外键),分数(0-100之间)
create table scoreInfo( scoreInfoID number primary key, scoreInfo_stuInfoID number references stuInfo(stuInfoID), scoreInfo_subInfoID number references subInfo(subInfoID), score number check(score >= 0 and score <= 100) ) /
二. 分别向三张表中插入数据,不少于5行
stuInfo表插入数据:
//stuInfo表 insert into stuInfo values(1,'张三','男',to_date('1990-01-01','yyyy-MM-dd')); insert into stuInfo values(2,'李四','男',to_date('1990-02-01','yyyy-MM-dd')); insert into stuInfo values(3,'王五','女',to_date('1990-03-01','yyyy-MM-dd')); insert into stuInfo values(4,'马六','男',to_date('1990-04-01','yyyy-MM-dd')); insert into stuInfo values(5,'刘七','女',to_date('1990-05-01','yyyy-MM-dd')); insert into stuInfo values(6,'小明','男',to_date('2003-06-01','yyyy-MM-dd')); insert into stuInfo values(7,'小红','女',to_date('2002-07-01','yyyy-MM-dd')); insert into stuInfo values(8,'小亮','男',to_date('2002-07-01','yyyy-MM-dd'));
stuInfo表插入数据后的效果:
select stuInfoID as 学号,stuInfoName as 姓名,stuInfoSex as 性别,stuInfoBrithday as 生日 from stuInfo;
subInfo表插入数据:
//subInfo表 insert into subInfo values(1,'语文'); insert into subInfo values(2,'数学'); insert into subInfo values(3,'英语'); insert into subInfo values(4,'物理'); insert into subInfo values(5,'化学'); insert into subInfo values(6,'生物'); insert into subInfo values(7,'地理'); insert into subInfo values(8,'历史');
subInfo表插入数据后的效果:
select subInfoID as 编号,subInfoName as 课程名 from subInfo;
score表插入数据:
//score表 insert into scoreInfo values(1,1,1,95); insert into scoreInfo values(2,2,2,97); insert into scoreInfo values(3,3,3,100); insert into scoreInfo values(4,4,4,86); insert into scoreInfo values(5,5,5,89); insert into scoreInfo values(6,6,6,91); insert into scoreInfo values(7,7,7,93); insert into scoreInfo values(8,8,8,90);
scoreInfo表插入数据后的效果:
select scoreInfoId as 编号,scoreInfo_stuInfoID as 学号,scoreInfo_subInfoID as 课程号,score as 分数 from scoreInfo;
三. 创建新表stu1并将stuinfo中的性别为女的学生的学号
姓名和性别的信息插入到该表中
create table stu1 as select stuInfoId,stuInfoName,stuInfoSex from stuInfo where stuInfoSex='女';
效果:
select stuInfoId as 学号,stuInfoName as 姓名,stuInfoSex as 性别 from stu1;
四. 完成下列查询
1.查询所有姓张的学员信息(模糊查询)
select stuInfoId as 学号,stuInfoName as 姓名,stuInfoSex as 性别 ,stuInfoBrithday as 生日 from stuInfo where stuInfoName like '张%';
2.查询所有20岁以上的学员信息(用日期函数实现)
select stuInfoId as 学号,stuInfoName as 姓名,stuInfoSex as 性别 ,stuInfoBrithday as 生日 from stuInfo where months_between(sysdate,stuInfoBrithday)/12>20;
3.查询同一天出生的学员信息(表连接)
select a .stuInfoID as 编号,a.stuInfoName as 姓名,a.stuInfoSex as 性别,a.stuInfoBrithday as 生日,b.score as 成绩 from stuInfo a left join scoreInfo b on a.stuInfoID = b.scoreInfoID where a.stuInfoBrithday in (select stuInfoBrithday from stuInfo group by stuInfoBrithday having count(stuInfoBrithday)>1);
4.查询参加考试的所有学员的名称,科目和成绩(按成绩排序)
select c.scoreInfoID as 学生编号,a.stuInfoName as 学生姓名,b.subInfoName as 课程名称 ,c.score as 课程成绩 from stuInfo a,subInfo b,scoreInfo c where a.stuInfoID = c.scoreInfo_stuInfoID and b.subInfoID = c.scoreInfo_subInfoID order by c.score asc;
5.查询所有没有参加考试的学员学号,姓名,只要有1门课没考都要查询出来(子查询)
select stuInfoID as 学员学号,stuInfoName as 姓名 from stuInfo where stuInfoID = (select scoreInfo_stuInfoID from scoreInfo where score is null);
6.查询出没有学生考试的课程名称
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。