前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >数据库原理与应用【实验报告】

数据库原理与应用【实验报告】

作者头像
苦咖啡
发布于 2018-05-07 08:28:03
发布于 2018-05-07 08:28:03
2.9K0
举报
文章被收录于专栏:我的博客我的博客

实验一 数据库管理系统软件的使用

一、实验目的

(1)认识几种常见的数据库管理系统,熟悉它们的使用界面;

(2)熟练掌握建立数据库和表,向数据库输入数据、修改数据和删除数据的操作。

二、实验内容

分别在Access 和SQL SERVER2000 中建立数据库并设计各表,输入多条实际数据,并实现

数据的增、删、改操作。

三、实验步骤:

分别在ACCESS数据库管理系统和SQL SERVR 2005环境下利用图形操作界面(非SQL语句)实现以下操作:

1、创建用于学生管理数据库,数据库名为对表中的记录进行浏览、修改、删除操作。本信息,课程信息和选课信息。

数据库XSGL包含下列3 个表:

(l) student:学生基本信息。

(2)course:课程信息表。

(3)sc:学生选课表。

各表的结构分别如表1、表2和表3 所示。

表1 学生信息表:student

列名

数据类型

长度

完整性约束

sno

字符(文本)型

8

主键

sname

字符(文本)型

4

不为空

ssex

字符(文本)型

2

sage

整数(数值)型

sdept

字符型

10

表2 课程信息表:course

列名

数据类型

长度

完整性约束

cno

字符(文本)型

2

主键

cname

字符(文本)型

30

credit

整数(数值)型

cpno

字符(文本)型

3

表3 学生选课表:sc

列名

数据类型

长度

完整性约束

sno

字符(文本)型

10

主属性,外键

cno

字符(文本)型

30

主属性,外键

grade

整数(数值)型

提示:在不使用SQL语句创建表的情况下,可通过ACCESS中的关系(菜单—工具—关系)和SQL SERVER 2005中的数据库关系图(数据库节点展开—数据库关系图)实现外键的创建。外键字段和参照字段之间的数据类型以及长度要保持一致。

2、输入表中的记录

分别在student表、course表和sc表中输入如下表中的记录:

sno

sname

ssex

sage

sdept

95001

李勇

20

CS

95002

刘晨

19

IS

95003

王敏

18

MA

95004

张立

19

IS

95005

刘云

18

CS

cno

cname

credit

pcno

1

数据库

4

5

2

数学

6

3

信息系统

3

1

4

操作系统

4

6

5

数据结构

4

7

6

数据处理

3

7

PASCAL语言

4

6

sno

cno

grade

95001

1

92

95001

2

85

95001

3

88

95002

2

90

95002

3

80

95003

2

85

95004

1

58

95004

2

85

    观察输入时有无提示错误,如果有如何修改,体会参照完整性的作用,弄清楚先输入那些表中记录,为什么?

3、对表中的记录进行浏览、修改、删除操作。

实验二 SQL语言(一) SQL定义语言

目的:

会用SQL语言进行基本表的结构的定义、修改、删除,会建立与删除索引; 

内容:

用SQL语言进行基本表结构的定义、修改、删除,索引的建立和删除

步骤:

1、 在SQL SERVER 2005中新建查询,建立到服务器的连接

2、 用SQL语言CREATE TABLE语句创建实验一中学生表student、课程表course

   和选课表sc及其相应约束,

   具体约束如下:

表1 学生信息表:student

列名

数据类型

长度

完整性约束

sno

字符(文本)型

8

主键

sname

字符(文本)型

4

不为空

ssex

字符(文本)型

1

默认值为’男’取值为’男’或’女’

sage

整数(数值)型

sdept

字符型

10

表2 课程信息表:course

列名

数据类型

长度

完整性约束

cno

字符(文本)型

2

主键

cname

字符(文本)型

30

credit

整数(数值)型

cpno

字符(文本)型

3

表3 学生选课表:sc

列名

数据类型

长度

完整性约束

sno

字符(文本)型

10

主属性,外键

cno

字符(文本)型

30

主属性,外键

grade

整数(数值)型

取值在0-100之间

3、向创建的表中输入数据,测试所创建的完整性约束是否起作用

4、用SQL语言ALTER语句修改表结构;

1) STUDENT表中增加一个字段入学时间scome,

2) 删除STUDENT表中sdept字段;

3) 删除创建的SC表中CNO字段和COURSE表CNO字段之间的外键约束;

4) 重建3)中删除的约束

5、重新定义一个简单表,然后用SQL语言DROP语句删除该表结构;

6、用SQL语言CREATE INDEX语句定义表STUDENT的SNAME字段的降序唯一索引;

7、用SQL语言DROP语句删除索引;

实验三 SQL(二)  SQL语言进行简单查询

目的:

掌握简单数据查询操作。

内容:

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

步骤:

1)创建学生表student、课程表course和选课表SC,并输入数据(注意数据的完整性。);(可以使用实验一中已经建立的表和数据)

2) 对各表中的数据进行不同条件的查询;

包括的运算:投影、选择、比较运算符、逻辑运算符、字符匹配运算符、匹配列表范围、算术运算符、内部函数、排序、分组、分组函数使用

(1) 查询全体学生的学号和姓名

(2) 查询全体学生的详细记录

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

(4) 查询所有选修过课程的学生学号(不重复)

(5) 查询考试不及格的学生学号(不重复)

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

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

(8) 查询姓刘的学生情况

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

(10) 查询姓刘且名字为两个字的学生情况

(11) 查询1983年以后出生的学生姓名。

(12) 创建表 studentgrad(sno,mathgrade,englishigrade,chinesegrade)

计算学生各科总成绩并赋予别名

(13) 利用内部函数 year()查找软件学院学生的出生年份

(14) 利用字符转换函数实现字符联接。

       Select sname + ‘年龄为’+cstr(sage)+’岁’

       From student

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

(16) 查询学生总人数。

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

(18) 查询选修了7号课程的学生总人数和平均成绩

(19) 查询选修6号课程学生的最好成绩

(20) 查询每个系的系名及学生人数。

(21) 查找每门课的选修人数及平均成绩

(22) 查找没有先修课的课程情况

要求:

1、将上述任务中完整的SQL语句调试并使之运行正确;

2、写出实验报告(在实验报告纸上完成,包括预习报告、上机报告、总结报告)实验四 SQL(三)  SQL进行复杂查询

目的:

掌握复杂数据查询操作。

内容:

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

步骤:

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

2) 对各表中的数据进行不同条件的连接查询和嵌套查询;

l 查询每个学生及其选课情况;

l 查询每门课的间接先修课

l 将STUDENT,SC进行右连接

l 查询既选修了2号课程又选修了3号课程的学生姓名、学号;

l 查询和刘晨同一年龄的学生

l 选修了课程名为“数据库”的学生姓名和年龄

l 查询其他系比IS系任一学生年龄小的学生名单

l 查询其他系中比IS系所有学生年龄都小的学生名单

l 查询选修了全部课程的学生姓名

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

l 查询选修课程1的学生集合和选修2号课程学生集合的差集

l 查询李丽同学不学的课程的课程号

l 查询选修了3号课程的学生平均年龄

l 求每门课程学生的平均成绩

l 统计每门课程的学生选修人数(超过3人的才统计)。要求输出课程号和选修人数,结果按人数降序排列,若人数相同,按课程号升序排列

l 查询学号比刘晨大,而年龄比他小的学生姓名。

l 求年龄大于所有女同学年龄的男同学姓名和年龄

要求:

1、将上述任务中完整的SQL语句调试并使之运行正确;

2、写出实验报告(在实验报告纸上完成,包括预习报告、上机报告、总结报告)

实验五 SQL(四)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、写出实验报告(在实验报告纸上完成,包括预习报告、上机报告、总结报告)

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2011年5月6日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
​数据库原理及应用上机(实验三 SQL数据查询)
🍓🍓前言: 数据库原理及应用上机实验报告的一个简单整理后期还会不断完善🍓🍓
命运之光
2024/03/20
6090
​数据库原理及应用上机(实验三 SQL数据查询)
数据库原理期末复习总结
本文内容为我大三上学期数据库原理期末复习时总结的知识点,文章分为三部分:第一部分是手写的知识点总结,第二部分是电子版的简答题总结,第三部分是部分SQL练习题及其解析!
Cyril-KI
2022/09/19
7690
数据库原理期末复习总结
数据库系统:第三章 关系数据库标准语言SQL
SQL是结构化查询语言(Structured Query Language)的缩写,是关系数据库的标准语言,实际功能包括数据定义、数据查询、数据操纵和数据控制。SQL标准的制定使得几乎所有的数据库厂家都采用SQL语言作为其数据库语言。但各家又在SQL标准的基础上进行扩充,形成自己的语言。
Here_SDUT
2022/08/09
2.9K0
数据库系统:第三章 关系数据库标准语言SQL
【数据库】实验2 单表查询
1.熟练掌握SQL Server查询分析器的使用方法,加深对标准SQL查询语句的理解。
韩旭051
2020/06/22
1.1K0
​数据库原理及应用上机(实验四 SQL连接查询)
🍓🍓前言: 数据库原理及应用上机实验报告的一个简单整理后期还会不断完善🍓🍓
命运之光
2024/03/20
5220
​数据库原理及应用上机(实验四 SQL连接查询)
数据库学习笔记(一)
创建基本表(以及其他数据库对象),如果没有指定模式,系统会根据搜索对象来确定该对象所属的模式
赤蓝紫
2023/01/02
1.3K0
SQL之学生选课数据库
Restrict说明删除是有条件的,cascade说明该表的删除没有任何限制。
牛老师讲GIS
2018/10/23
2.2K0
SQL之学生选课数据库
SQL之单表查询
附上下面要用到的数据库和表的 SQL 语句,在数据库管理页面新建一个查询然后使用 CV 大法转移过去执行即可:
wsuo
2020/07/30
1.8K0
​数据库原理及应用上机(实验五 SQL的数据更新)
🍓🍓前言: 数据库原理及应用上机实验报告的一个简单整理后期还会不断完善🍓🍓
命运之光
2024/03/20
4050
​数据库原理及应用上机(实验五 SQL的数据更新)
​数据库原理及应用上机(实验二 SQL数据定义功能实验)
🍓🍓前言: 数据库原理及应用上机实验报告的一个简单整理后期还会不断完善🍓🍓
命运之光
2024/03/20
8830
​数据库原理及应用上机(实验二 SQL数据定义功能实验)
数据库实验报告
1.安装配置MySQL workbench或者sqlyog客户端,并实现服务的连接。
十二惊惶
2024/02/28
3730
SQL数据查询之——单表查询
一、SQL数据查询的一般格式 数据查询是数据库的核心操作。SQL提供了SELECT语句进行数据查询,其一般格式为: SELECT [ALL | DISTINCT]<目标列表达式>[,<目标列表达式>]··· FROM<表名或视图名>[,<表名或视图名>···] | (SELECT语句>)[AS]<别名> [WHERE<条件表达式>] [GROUP BY<列名1>[HAVING<条件表达式>]] [ORDER BY<列名2>[ASC | DESC]]; 整个SELECT语句的含义是,根据WHERE子句的条件表
Zoctopus
2018/06/04
1.9K0
​数据库原理及应用上机(实验六 视图的定义和维护)
🍓🍓前言: 数据库原理及应用上机实验报告的一个简单整理后期还会不断完善🍓🍓
命运之光
2024/03/20
2640
​数据库原理及应用上机(实验六 视图的定义和维护)
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(一)模式、表、索引与视图
在 SQL Server 中,标识符(例如表名、列名、数据库名等)默认是不区分大小写的,但是字符串常量是区分大小写的【仅支持英文版双引号("")】。
SarPro
2024/03/16
4260
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(一)模式、表、索引与视图
3.4 《数据库系统概论》之数据查询—SELECT(单表查询、连接查询、嵌套查询、集合查询、多表查询)
[例5] 查询全体学生的姓名、出生年份和所有系,要求用小写字母表示所有系名,这里假定目前年份是2004年。
全栈程序员站长
2022/07/01
6.3K0
3.4 《数据库系统概论》之数据查询—SELECT(单表查询、连接查询、嵌套查询、集合查询、多表查询)
用SQL语句进行数据库查询(复杂查询)
(4)查询选修了“C语言程序设计”的学生的学号与姓名 –a.用内连接查询 语句:
初阶牛
2023/01/04
1.8K0
用SQL语句进行数据库查询(复杂查询)
haue数据库原理第一次实验
(1)学会使用MySQL 图形界面工具进行数据库相关操作。 (2)掌握使用SQL语句创建、选择、删除数据库。 (3)掌握使用SQL语句创建、修改、删除表。 (4)掌握使用SQL语句对表进行插入、修改和删除数据操作。 (5)学会使用SQL命令进行数据库备份的操作方法。 (6)学会使用SQL命令进行数据库恢复的操作方法。
南桥
2024/11/02
1140
haue数据库原理第一次实验
手把手教你 SQL 多表查询
本文通过经典的学生-课程模式 S-T 数据库带大家学习 SQL 常用的多表查询 :
wsuo
2020/07/31
1.9K0
手把手教你 SQL 多表查询
【数据库SQL server】关系数据库标准语言SQL之视图
【1】建立信息系学生的视图。 CREATE VIEW IS_Student AS SELECT Sno,Sname,Sage FROM Student WHERE Sdept= 'IS'; 【1】建立信息系学生的视图,并要求进行修改和插入操作时仍需保证该视图只有信息系的学生 。 CREATE VIEW IS_Student AS SELECT Sno,Sname,Sage FROM Student WHERE Sdept= 'IS' WITH CHECK OPTION; 【1】 建立信息系选修了1号课程的学生的视图(包括学号、姓名、成绩)。 CREATE VIEW IS_S1(Sno,Sname,Grade) AS SELECT Student.Sno,Sname,Grade FROM Student,SC WHERE Sdept= 'IS' AND Student.Sno=SC.Sno AND SC.Cno= '1'; 【1】 建立信息系选修了1号课程且成绩在90分以上的学生的视图。 CREATE VIEW IS_S2 AS SELECT Sno,Sname,Grade FROM IS_S1 WHERE Grade>=90; 带表达式的视图 【1】定义一个反映学生出生年份的视图。 CREATE VIEW BT_S(Sno,Sname,Sbirth) AS SELECT Sno,Sname,2014-Sage FROM Student; 分组视图 【1】将学生的学号及平均成绩定义为一个视图 CREAT VIEW S_G(Sno,Gavg) AS SELECT Sno,AVG(Grade) FROM SC GROUP BY Sno; 【1】将Student表中所有女生记录定义为一个视图 CREATE VIEW F_Student(F_Sno,name,sex,age,dept) AS SELECT * /*没有不指定属性列*/ FROM Student WHERE Ssex=‘女’; 缺点:修改基表Student的结构后,Student表与F_Student视图 的映象关系被破坏,导致该视图不能正确工作。
SarPro
2024/02/20
2680
SQL 数据查询(4)—— 嵌套查询
常见的比较运算符是>,<,=,>=,<=,!=,<>等。 例3.55中的IN就可以用 = 来实现
全栈程序员站长
2022/09/22
1.4K0
SQL 数据查询(4)—— 嵌套查询
推荐阅读
相关推荐
​数据库原理及应用上机(实验三 SQL数据查询)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档