数据库小练习

一、            设有一数据库,包括四个表:学生表(Student)、课程表(Course)、成绩表(Score)以及教师信息表(Teacher)。四个表的结构分别如表1-1的表(一)~表(四)所示,数据如表1-2的表(一)~表(四)所示。用SQL语句创建四个表并完成相关题目。

1-1数据库的表结构 

表(一)Student (学生表)


字段名


数据类型


可否为空


含 义


Sno


Varchar2(3)



学号(主键)


Sname


Varchar2(8)



学生姓名


Ssex


Varchar2(2)



学生性别


Sbirthday


Date



学生出生年月


SClass


Varchar2(5)



学生所在班级

表(二)Course(课程表)


属性名


数据类型


可否为空


含 义


Cno


Varchar2(5)



课程号(主键)


Cname


Varchar(10)



课程名称


Tno


Varchar2(3)



教工编号(外键)

表(三)Score(成绩表)


属性名


数据类型


可否为空


含 义


Sno


Varchar2(3)



学号(外键)


Cno


Varchar2(5)



课程号(外键)


Degree


Number(4,1)



成绩


主键:Sno+ Cno

表(四)Teacher(教师表)


属性名


数据类型


可否为空


含 义


Tno


Varchar2(3)



教工编号(主键)


Tname


Varchar2(4)



教工姓名


Tsex


Varchar2(2)



教工性别


Tbirthday


Date



教工出生年月


Prof


Varchar2(6)



职称


Depart


Varchar(10)



教工所在部门

1-2数据库中的数据

表(一)Student


Sno


Sname


Ssex


Sbirthday


class


108


曾华



1977/09/01


95033


105


匡明



1975/10/02


95031


107


王丽



1976/01/23


95033


101


李军



1976/02/20


95033


109


王芳



1975/02/10


95031


103


陆君



1974/06/03


95031

表(二)Course


Cno


Cname


Tno


3-105


计算机导论


825


3-245


操作系统


804


6-166


数字电路


856


9-888


高等数学


831

表(三)Score


Sno


Cno


Degree


103


3-245


86


105


3-245


75


109


3-245


68


103


3-105


92


105


3-105


88


109


3-105


76


101


3-105


64


107


3-105


91

 

108


3-105


78

 

101


6-166


85

 

107


6-166


79

 

108


6-166


81

 

表(四)Teacher


Tno


Tname


Tsex


Tbirthday


Prof


Depart


804


李诚



1958/12/02


副教授


计算机系


856


张旭



1969/03/12


讲师


电子工程系


825


王萍



1972/05/05


助教


计算机系


831


刘冰



1977/08/14


助教


电子工程系

1、 查询Student表中的所有记录的Sname、Ssex和Class列。

2、 查询教师所有的单位即不重复的Depart列。

3、 查询Student表的所有记录。

4、 查询Score表中成绩在60到80之间的所有记录。

5、 查询Score表中成绩为85,86或88的记录。

6、 查询Student表中“95031”班或性别为“女”的同学记录。

7、 以Class降序查询Student表的所有记录。

8、 以Cno升序、Degree降序查询Score表的所有记录。

9、 查询“95031”班的学生人数。

10、 查询Score表中的最高分的学生学号和课程号。(子查询或者排序)

11、 查询每门课的平均成绩。

12、查询Score表中至少有5名学生选修的并以3开头的课程的平均分数。

13、查询分数大于70,小于90的Sno列。

14、查询所有学生的Sname、Cno和Degree列。

15、查询所有学生的Sno、Cname和Degree列。

16、查询所有学生的Sname、Cname和Degree列。

17、 查询“95033”班学生的平均分。

18、 假设使用如下命令建立了一个grade表:

create table grade(low  number(3),upp  number (3),rank  char(1))

insert into grade values(90,100,’A’)

insert into grade values(80,89,’B’)

insert into grade values(70,79,’C’)

insert into grade values(60,69,’D’)

insert into grade values(0,59,’E’)

现查询所有同学的Sno、Cno和rank列。

19、  查询选修“3-105”课程的成绩高于“109”号同学成绩的所有同学的记录。

20、查询score中选学多门课程的同学中分数为非最高分成绩的记录。

21、 查询成绩高于学号为“109”、课程号为“3-105”的成绩的所有记录。

22、查询和学号为108的同学同年出生的所有学生的Sno、Sname和Sbirthday列。

23、查询“张旭“教师任课的学生成绩。

24、查询选修某课程的同学人数多于5人的教师姓名。

25、查询95033班和95031班全体学生的记录。

26、  查询存在有85分以上成绩的课程Cno.

27、查询出“计算机系“教师所教课程的成绩表。

28、查询“计算机系”与“电子工程系“不同职称的教师的Tname和Prof。

29、查询选修编号为“3-105“课程且成绩至少高于选修编号为“3-245”的同学的Cno、Sno和Degree,并按Degree从高到低次序排序。

30、查询选修编号为“3-105”且成绩高于选修编号为“3-245”课程的同学的Cno、Sno和Degree.

31、 查询所有教师和同学的name、sex和birthday.

32、查询所有“女”教师和“女”同学的name、sex和birthday.

33、 查询成绩比该课程平均成绩低的同学的成绩表。

34、 查询所有任课教师的Tname和Depart.

35 、 查询所有未讲课的教师的Tname和Depart.

36、查询至少有2名男生的班号。

37、查询Student表中不姓“王”的同学记录。

38、查询Student表中每个学生的姓名和年龄。

39、查询Student表中最大和最小的Sbirthday日期值。

40、以班号和年龄从大到小的顺序查询Student表中的全部记录。

41、查询“男”教师及其所上的课程。

42、查询最高分同学的Sno、Cno和Degree列。

43、查询和“李军”同性别的所有同学的Sname.

44、查询和“李军”同性别并同班的同学Sname.

45、查询所有选修“计算机导论”课程的“男”同学的成绩表。

时间: 2024-10-05 20:35:57

数据库小练习的相关文章

oracle数据库小总结

---数据库小总结--- 1.数据库的基本常用数据类型 ①varchar2(size)      //浮动长度字符类型:长度会改变,根据用户输入的值进行相应的长度改变,节省内存空间 ②char(size)     //固定字符长度,如果用户输入的值得长度,不够size,则系统默认用空格代替 ③number(1,2)     //数字类型,包含小数和整数(1.代表数字的总长度/位数  2.表示小数点后的长度/位数) ④date //时间类型  sysdate(系统时间) to_date('输入的时

数据库小工具Sqlite Developer

SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了.它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl.C#.PHP.Java等,还有ODBC接口,同样比起Mysql.PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快.SQLite第一个Alpha版本诞生于2

带你了解MySQL数据库小技巧

兴趣是最好的老师,不论学习什么知识,兴趣都可以极大地提高学习效率.当然学习MySQL 5.6也不例外.本文列举37 个 MySQL 数据库小技巧,快来学习吧! 37 个 MySQL 数据库小技巧! 1.如何快速掌握MySQL? 培养兴趣 兴趣是最好的老师,不论学习什么知识,兴趣都可以极大地提高学习效率.当然学习MySQL 5.6也不例外. 夯实基础 计算机领域的技术非常强调基础,刚开始学习可能还认识不到这一点,随着技术应用的深 入,只有有着扎实的基础功底,才能在技术的道路上走得更快.更远.对于M

数据库小知识点

元组是关系数据库中的基本概念,关系是一张表, 表中的每行(即数据库中的每条记录)就是一个元组 ,每列就是一个属性. 在二维表里,元组也称为记录. 要删除表A中数据,使用TRUNCATE TABLE A.运行结果是表A中的约束依然存在! 删除表的语句为:DROP TABLE table_name; 而DELETE和TRUNCATE TABLE都是删除表中的数据的语句,它们的不同之处在于: 1.TRUNCATE TABLE比DELETE的速度快: 2.TRUNCATE TABLE 是删除表的所有行,

SqlHelper——数据库小助手

SqlHelper事实上就是一个类. 早就听说过"SqlHelper"这个名词.也查过相关的资料.但还是一头雾水.当真的去实践去用它时,就会发现事实上它没那么神奇. 当敲第一个窗口的时候.功能实现了,我们就会认为非常高兴.大功告成了.但是当敲完第二个窗口.第三个窗口的时候,慢慢的就開始认为代码反复的太多了.越敲就越认为心虚.尽管设计模式学的不怎么样,但是最起码让我有了这个意识去想怎么让代码更少一些.让彼此之间的耦合度尽量降低. 在三层中,要数D层的代码相似度最高了,总结来说,也就是连接

数据库小知识

数据库管理软件分类 mysql就是一个基于socket编写的C/S架构的软件 分两大类: 关系型:如sqllite,db2,oracle,access,sql server,MySQL,注意:sql语句通用 非关系型:mongodb,redis,memcache 总结两句话: 关系型数据库需要有表结构 非关系型数据库是key-value存储的,没有表结构 存储引擎 数据库中的表也应该有不同的类型,表的类型不同,会对应mysql不同的存取机制,表类型又称为存储引擎. ps: 存储引擎说白了就是如何

python操作mysql数据库小程序,用户登陆验证

已经建立一个mysql数据库school,里面包含一个表userinfo,表里有3个字段,分别为user_id,username,passwd,即序号(自增字段),用户名,密码. 已经该数据库中存放了若干用户的帐户信息,现在要求用python编写一段小程序,实现由用户输入自己的用户名和密码,完成登陆验证,输入正确的帐号, 显示"welcome",非正确的帐号,显示"failed log in" import pymysql conn = pymysql.connec

Android中SQLite数据库小计

2016-03-16 Android数据库支持 本文节选并翻译<Enterprise Android - Programing Android Database Applications for the Enterprise>.学习目标: 学习Android对SQL的支持. 理解在Java中使用SQL——通过SQLiteDatabase类. 创建数据库——SQLiteOpenHelper类. 理解loaders.cursors和adapters. 为了在程序中使用本地的,结构化的数据,需要完成

Sql Server数据库小知识点总结

把我在开发时候遇到的一点小知识持续更新在这里~ 1.where条件时常变 where UserID='1' 这里的UserID呢,它的值是经常在变化的,有时候要查2,有时候要查3的,有时候要查全部人!这里定义一个函数传参数的时候,查全部人这里需要搞一个if分支判断一下,但是呢,不需要~~好的办法来了 select * from 表 Where UserID="+UserID+" 大概就是这样子,UserID是一个参数,你有需要的时候直接传给我1或者2或者其他数字都OK,但是你不需要这个