sql数据库系统原理上机实验(综合版)(2)

2019-04-17 15:16

实验二 SQL简单查询

目的:

掌握简单数据查询操作。

内容:

使用各种查询条件完成指定的查询操作 步骤:

1)创建学生表student、课程表course和选课表SC,并输入数据(注意数据的完整性。);(可以使用实验一中已经建立的表和数据) 2) 对各表中的数据进行不同条件的查询;

包括的运算:投影、选择、比较运算符、逻辑运算符、字符匹配运算符、匹配列

表范围、算术运算符、内部函数、排序、分组、分组函数使用

(1) 查询全体学生的学号和姓名 (2) 查询全体学生的详细记录

(3) 查询软件学院的学生姓名、年龄、系别

(4) 查询所有选修过课程的学生学号(不重复) (5) 查询考试不及格的学生学号(不重复)

(6) 查询不是软件学院的学生性别、年龄、系别

(7) 查询年龄18-20岁的学生学号、姓名、系别、年龄; (8) 查询姓刘的学生情况

(9) 查询姓刘或姓李的学生情况

(10) 查询姓刘且名字为两个字的学生情况 (11) 查询1983年以后出生的学生姓名。

(12) 利用内部函数 year()查找软件学院学生的出生年份 (13) 利用字符转换函数实现字符联接。

Select sname + ‘年龄为’+cast(sage as char(2))+’岁’ From student

(14) 查询全体学生情况,查询结果按所在系升序排列,对同一系中的学

生按年龄降序排列。 (15) 查询学生总人数。

(16) 查询选修了课程的学生人数。

(17) 查询选修了7号课程的学生总人数和平均成绩 (18) 查询选修6号课程学生的最好成绩 (19) 查询每个系的系名及学生人数。 (20) 查找每门课的选修人数及平均成绩 (21) 查找没有先修课的课程情况

要求:

1、将上述任务中完整的SQL语句调试并使之运行正确; 2、写出实验报告;

6

实验三 SQL 复杂查询

目的:

掌握复杂数据查询操作。

内容:

掌握各种连接查询、嵌套查询的使用

步骤:

1)实验一中的数据为基础

2) 对各表中的数据进行不同条件的连接查询和嵌套查询; ? 查询每个学生及其选课情况; ? 查询每门课的间接先修课 ? 将STUDENT,SC进行右连接

? 查询既选修了2号课程又选修了3号课程的学生姓名、学号; ? 查询和刘晨同一年龄的学生

? 选修了课程名为“数据库”的学生姓名和年龄 ? 查询其他系比IS系任一学生年龄小的学生名单

? 查询其他系中比IS系所有学生年龄都小的学生名单 ? 查询选修了全部课程的学生姓名

? 查询计算机系学生及其性别是男的学生

? 查询选修课程1的学生集合和选修2号课程学生集合的差集 ? 查询李丽同学不学的课程的课程号 ? 查询选修了3号课程的学生平均年龄 ? 求每门课程学生的平均成绩

? 统计每门课程的学生选修人数(超过3人的才统计)。要求输出课程号和

选修人数,结果按人数降序排列,若人数相同,按课程号升序排列 ? 查询学号比刘晨大,而年龄比他小的学生姓名。 ? 求年龄大于所有女同学年龄的男同学姓名和年龄

要求:

1、将上述任务中完整的SQL语句调试并使之运行正确; 2、写出实验报告;

7

实验四 SQL 数据更新

目的:

掌握SQL的常用数据更新操作,熟练应用INSERT,UPDATE,DELETE语句。

内容:

1)应用INSERT,UPDATE,DELETE语句进行更新操作;

a) 插入如下学生记录(学号:95030,姓名:李莉,年龄:18) b) 插入如下选课记录(95030,1) c) 计算机系学生年龄改成20 d) 把数学系所有学生成绩改成0

e) 把低于总平均成绩的女同学成绩提高5分

f) 修改2号课程的成绩,若成绩小于75分提高5%,成绩大于75时提高

4%(两个语句实现,注意顺序) g) 删除95030学生信息

h) 删除SC表中无成绩的记录 i) 删除张娜的选课记录

j) 删除不及格的学生选课记录 k) 删除数学系所有学生选课记录 l) 删除所有未被选修的课程

m) 查询每一门课程成绩都大于等于80分的学生学号、姓名和性别,把值送

往另一个已经存在的基本表STU(SNO,SNAME,SSEX)中

n) 建立一个sdeptgrade 表,包含(sdept,avggrade)字段,对每一个系,求

学生的成绩,并把结果存入sdeptgrade

2)熟练掌握INSERT,UPDATE,DELETE语句并能综合应用;

要求:

1、将上述任务中完整的SQL语句调试并使之运行正确; 2、写出实验报告;

8

附录(总版): 语句清单

--sql 查询实验一代码

create table student1 (sno char(8) primary key,

sname char(4) not null, ssex char(2) default'男', check(ssex in('男','女')), sage int default('是'), sdept char(10) default('否'), )

create table course1 (cno char(2) primary key,

cname char(30), credit int, cpno char(3), )

-------创建表student1 ------创建表course1 9

create table sc1

(sno char(8) foreign key references student1(sno), 创建表sc1 cno char(2) foreign key references course1(cno), grade int default('是') check(grade between 0 and 100), )

----------------------第题

alter table student1 add scome int alter table student1 drop column sdept

select name

from sys.foreign_key_columns f join sys.objects o on f.constraint_object_id=o.object_id

where f.parent_object_id=object_id('sc1') --------查找出约束名,然后再用drop语句删除约束

alter table sc1 drop constraint FK__sc1__cno__740F363E --------在括号中补充用上面语句查找出的约束名

alter table sc1 add constraint [pk_sc1] primary key (cno)

alter table sc1 add constraint [fk_sc1_course1] foreign key (cno) references course1(cno)

alter table sc1 drop constraint [fk_sc1_course1]

10


sql数据库系统原理上机实验(综合版)(2).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:2017年10月自考02120数据库及其应用试题及答案

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: