数据库及其应用实验报告.docx
- 文档编号:27461115
- 上传时间:2023-07-01
- 格式:DOCX
- 页数:44
- 大小:2.04MB
数据库及其应用实验报告.docx
《数据库及其应用实验报告.docx》由会员分享,可在线阅读,更多相关《数据库及其应用实验报告.docx(44页珍藏版)》请在冰豆网上搜索。
数据库及其应用实验报告
《数据库及其应用》实验报告
实验序号:
B0901000-02实验项目名称:
数据库设计及数据库创建与应用
学 号
1206100140
姓 名
专业、班
实验地点
现教中心
指导教师
金大卫
时间
2013年5-6月
一、实验目的及要求
(一)实验项目1:
数据库和表
1.熟悉Access中数据库及表的概念。
了解并掌握建立数据库、表和关系的过程。
2.熟悉数据库窗口的界面特点,掌握数据库窗口几种设置方法。
3.理解并掌握关系数据库完整性基本概念。
掌握完整性的设置方法。
4.掌握字段属性的概念和一些属性的用途。
并掌握一些字段属性的设置方法。
5.了解Access数据表视图的一些基本功能。
(二)实验项目2:
查询
1.掌握Access表达式的基本概念。
了解不同类型数据的常量、参数、运算与函数的使用。
2.理解查询对象的意义和建立方法。
3.掌握SQL语言中SELECT语句的主要应用。
4.掌握SQL的插入、更新、删除操作命令的基本应用。
理解Access动作查询。
5.了解SQL定义数据表的基本方法。
6.掌握一般选择查询的操作应用;理解并掌握交叉查询的应用;理解参数查询的意义。
(三)实验项目3:
数据交换
1.了解什么是Access的外部数据,理解Access与外部数据交换的意义和作用。
2.理解在Access数据库系统中使用外部数据的两种方法及特点:
链接、导入。
3.掌握导出数据库中表或查询对象到文本文件和EXCEL的方法。
4.掌握从文本文件和EXCEL表导入到表的方法。
二、实验设备(环境)及要求
PC机,WindowsXP,Access2003
参考教材:
《数据库及其应用(Access及Excel)学习与实验实训教程》。
三、实验内容要求
(实验操作内容和步骤写在表格后面、回答问题写在表给内)
实验项目1:
数据库设计及数据库与表的创建与操作
(一)数据库与表的设计与创建
1.给定如下数据分析,进行概念设计与逻辑设计。
即设计系统的E-R模型并转换为关系模型。
(数据参见附表)。
某学校设计学生教学管理系统。
学生实体包括学号、姓名、性别、生日、民族、籍贯、简历、登记照,每名学生选择一个主修专业,专业包括专业编号和名称,一个专业属于一个学院,一个学院可以有若干个专业。
学院信息要存储学院号、学院名、院长。
教学管理还要管理课程表和学生成绩。
课程表包括课程号、课程名、学分,每门课程由一个学院开设。
学生选修的每门课程获得一个成绩。
2.数据库结构设计
指定数据库文件的名称,并为设计好的关系模型设计表结构。
数据库文件保存在“E:
\教学管理\”文件夹中。
3.定义数据库文件
定义存放路径,和数据库文件。
写出操作步骤。
可包括必要的截图。
4.定义数据库中各表
根据事先设计好的结构,分别定义各表、字段名、字段属性。
重复的步骤可简化。
5.定义表之间的关系
当所有表都定义好后,定义各表之间的关系。
6.输入表记录
当所有表建立好后,可开始输入记录。
简要说明输入的操作。
(二)Access数据库窗口基本操作
1.设置教学管理数据库窗口中表对象列表窗口的显示格式为“详细信息”
写出操作步骤。
2.隐藏和重新显示教学管理数据库窗口
写出操作步骤。
3.定义一个“学生与成绩”组,将“学生”、“成绩”表放置到该组中
写出创建组的操作和放置对象的操作。
(三)创建表时的完整性设置
1.定义主键,实现实体完整性的操作
每个表都可以定义主键。
在Access中为教学管理数据库的各表定义主键。
当一个表没有合适的字段作为主键时,一般会增加一个“id”字段。
试在“成绩”表中增加一个“成绩id”字段,并定义为“自动编号”型,然后定义其为主键。
2.进行设置参照完整性的操作
在定义的有关系的表上,为关系设置参照完整性。
3.通过不同方式实现用户定义的完整性的操作
用户定义的完整性,是指由用户规定的对于表中数据取值的约束。
在Access表定义时,除定义主键和关系外,通过多种方式设置用户定义完整性。
对教学管理数据库中必要的用户定义完整性进行设置和定义。
(四)字段属性定义与应用
1.字段显示格式设置
①使“学生”表中的“民族”字段以黄色显示。
②使“学生”的生日以中文方式、红色显示。
③使“成绩”表中成绩的显示为3位整数和一位小数,蓝色。
2.字段输入掩码设置
在定义“学生”表时,由于“学号”是8位文本,且每位都由0~9组成,因此,要在定义“学号”字段时规定每一位的输入都必须是数字。
其他如课程表的“课程号”字段、专业表的“专业号”字段等都可以定义类似的输入掩码。
3.定义字段查阅方法
“查阅”控件与字段绑定,可以提示字段的输入。
为“专业”表的“专业类别”定义查阅控件绑定。
为“专业”表的“学院号”字段设计“查阅”控件。
数据从“学院”表中来,显示“学院号”和“学院名”两列数据,采用列表框。
(五)数据表视图下数据记录的显示与操作
1.输入操作
利用数据表视图进行输入操作,输入的数据应该满足完整性的要求。
而如果是有关系的表中的子表,外键输入时还要与主键值对应。
根据给定的数据,为数据库中各表(重点介绍一到两个表)输入记录。
2.修改和删除操作
修改“课程”表,将“运筹学”所在记录的学分增加1分,将开设学院变为“工商管理学院(05)”。
删除“课程”表中“美术设计”课程。
3.数据表视图中的设置
数据表视图是浏览表中数据的界面,可以做不同的设置,以获得不同的效果。
①数据表视图中父子表的展开。
②按照指定的字段排序浏览。
在“成绩”数据表视图中,按照成绩的大小排列。
③在学生表中只显示女生数据记录。
实验项目二:
查询
(一)SQL视图中表达式练习
1.进入SQL视图及在不同视图间切换
在Access中进入查询的设计视图并在查询的不同视图之间切换。
2.不同类型数据的表达式运算
在SQL视图中分别输入以下命令并运行,对于参数自己输入数据。
查看并写出各表达式运算结果。
SELECT-5.12^2+(17mod3);
SELECT"Hello"+",World!
",LEFT("清华大学出版社",2)+RIGHT("清华大学出版社",3);
SELECT"你毕业的年份是",VAL(LEFT([你的学号],4))+4;
SELECT"现在是"+STR(YEAR(DATE()))+"年","现在的时间是:
"+CSTR(TIME());
SELECT"张三">"李四","ABCD"<"abcd",(DATE()-#1992-10-8#)>1000;
(二)SQL命令进行查询和操作
1.练习SQL查询的SELECT语句
启动教学管理数据库,在数据库窗口对象栏中单击“查询”,然后进入SQL视图。
在“SQL视图”中输入以下SELECT命令,查看执行结果,并仔细体会查询的实现。
①查询“学院”、“专业”、“学生”完整数据。
SELECT*
FROM((学院INNERJOIN专业ON学院.学院号=专业.学院号)
INNERJOIN学生ON专业.专业号=学生.专业号);
②查询“工商管理”专业所有女生信息。
SELECT专业,学生.*
FROM专业INNERJOIN学生ON专业.专业号=学生.专业号
WHERE专业.专业="工商管理"AND学生.性别="女";
③查询平均成绩在80分以上的各位学生的学号、姓名和平均分。
保存为查询对象,对象名“优秀学生”。
SELECT学生.学号,姓名,AVG(成绩)AS平均分
FROM学生INNERJOIN成绩ON学生.学号=成绩.学号
GROUPBY学生.学号,姓名
HAVINGAVG(成绩)>=80;
单击工具栏保存按钮,弹出“另存为”对话框,输入“优秀学生”,单击“确定”按钮。
④查询没有学生数据的专业编号和专业。
SELECT专业号,专业
FROM专业
WHERE专业号NOTIN(SELECT专业号FROM学生);
⑤查询“湖北”籍1988年以后出生的学生信息。
SELECT*
FROM学生
WHERE籍贯LIKE"湖北*"AND生日>=#1988-1-1#;
⑥查询选课人数最多的课程的课程号、课程名。
SELECTTOP1课程.课程号,课程名
FROM课程INNERJOIN成绩ON课程.课程号=成绩.课程号
GROUPBY课程.课程号,课程名
ORDERBYCOUNT(*)DESC;
2.练习SQL的插入、更新、删除操作命令
①在课程表中插入一门新课,数据如命令所示。
INSERTINTO课程
VALUES("06020101","会计学原理",3,"06");
②将“法学院(04)”开设课程的学分增加1分。
UPDATE课程
SET学分=学分+1
WHERE学院号="04"
③删除“信息学院(09)”开设的没有学生选修的课程。
DELETEFROM课程
WHERE学院号="09"AND课程号NOTIN(SELECT课程号FROM成绩)
3.创建“教师”表,包括:
工号、姓名、性别、生日、职称、基本工资、学院号。
写出创建命令。
(三)选择查询操作
1.进入查询设计视图进行交互式选择查询设置
启动教学管理数据库。
①查询“专业”表,显示开设的所有专业涉及的学科门类。
②查询各专业学生的人数。
③查询没有选课的男学生学号、姓名,即成绩表中没有记录的学生数据。
2.进行交叉表查询
将学生的“学号”和“姓名”作为行标题,“课程名”作为列标题,成绩作为交叉数据,生成交叉表。
3.进行参数查询
通过参数查询指定日期以后出生的某个民族的学生信息。
(四)动作查询操作
1.生成表查询操作练习
将“查询平均成绩在80分以上的各位学生的学号、姓名和平均分”的结果生成新表,表名“优秀学生名单”。
2.删除查询操作
删除“优秀学生名单”表中,平均分在85分以下的记录。
3.追加查询操作
将平均分在80~85分之间的学生及成绩数据加入“优秀学生名单”表,
4.更新查询操作
将没有学生选修的课程的学分减少1分。
写出以上要求的操作步骤并截取必要的图片。
实验项目三:
数据交换
(一)导出操作
1.在“教学管理”数据库中创建一个查询并保存。
查询的名称为“学生成绩单”。
查询的结构为:
学号、姓名、专业、课程号、课程名、成绩。
2.将“学生成绩单”查询导出为文本文件,字段值之间用逗号作为分隔符,文本型数据不要加引号。
文本文件要包括字段名。
3.将“学生成绩单”查询导出到桌面EXCEL文件“学生成绩表”中。
写出以上操作的主要过程。
(二)导入操作
1.将上面实验产生的文本文件导入教学管理数据库中作为表对象。
命名为“学生成绩单”。
并为各字段列指定合适的类型。
2.上面实验产生的EXCEL文件“学生成绩表”导入教学管理数据库中作为表对象。
命名为“学生成绩表”。
并为各字段列指定合适的类型。
产生表后,指定学号、课程号为主键。
写出以上操作的主要过程。
四、回答问题
(一)实验项目1
1.Access存储数据时,用到几个数据库文件?
扩展名是什么?
答:
用到一个数据库,拓展名是mdb
2.设计ER模型、关系模型、数据库及表结构,分别属于数据库设计中的什么步骤?
答:
概念设计逻辑设计物理结构设计
3.在表结构设计中,应该包含哪些内容?
答:
字段名、类型、宽度、小数、主键/索引、参照表、约束、Null值
4.在本实验设计中,共使用了哪些数据类型?
答:
文本、备注、数字、日期/时间、自动编号、OLE对象
5.定义表之间的关系时,“实施参照完整性”的意义是什么?
在“编辑关系”对话框中选中或者撤销“级联更新相关字段”复选框,对于数据表的操作有何影响?
答:
当一个关系中的主键作为外键出现在另一个关系中,他在这个关系中只能否和2中情景,一个为空值,一个与原关系相同。
6.建立表的关系,是否要求发生关系的两个字段必须同名?
答:
否
7.在定义学生表的“性别”字段时,同时定义了字段的“有效性规则”,对输入学生表的记录有什么影响?
答:
只能输入男或女
8.如何输入学生照片?
答:
利用OLE对象,与相应的图片建立连接
9.如何理解“收藏夹”,试说明“收藏夹”与组之间的异同。
答:
收藏夹是自带的,无法删除。
它的作用与其他的组作用相同
10.打开数据库文件时,有哪几种可选择的方式?
一般默认方式是什么?
如果要将默认方式设置为“独占”如何实现?
答:
(1)选择“文件”菜单的“打开”项
(2)单击工具栏中的打开按钮,弹出打开对话框,在“查找范围”下拉框中选定文件路径,选中文件,单击“打开”按钮。
一般默认方式是打开文件的默认文件夹是“我的文档”。
单击工具栏中的“打开”按钮,弹出打开对话框,确定文件位置并选中文件,在“打开”按钮下拉菜单中,选择“以独占方式打开”。
11.在“学生”表的设计器中,选择“学号”字段,然后单击工具栏“主键”按钮,以便取消主键,这时会出现什么情况?
为什么?
答:
无法删除。
“学号还是其他表的外键”
12.在“编辑关系”对话框中,只有选中“实施参照完整性”,才可以选择“级联更新关联字段”和“级联删除关联字段”。
试解释这三种复选项的控制意义。
答:
“实施参照完整性”,Access将检验子表新加入的与主键有关的外键值是否满足参照完整性。
选中“级联更新关联字段”后,如果子表中的外键有对应值,外键的对应值将自动级联更新。
如果撤销该复选框,那么当父表修改主键值而子表中的外键有对应值,则Access拒绝修改主键值。
选中“级联删除关联字段”后,当父表删除主键值时,如果子表中的外键有对应值,外键所在的纪录将自动级联删除。
13.当在输入记录时,如果发生主键字段重复,会出现什么现象?
如果输入的外键值如专业表的“学院号”在“学院”中没有对应的值,会出现什么情况?
答:
二者均无法设置成功
14.定义表时,设置“有效性文本”字段属性有何作用?
答:
在你输入的数据不符合要求时,会提示你出现错误的原因
15.在定义“文本”型字段格式时,“@”符号与“&”符号作为占位符有何区别?
在定义“数字”型字段格式时,“#”符号与“0”符号作为占位符有何区别?
答:
&如果没有可用字符要显示,Access将忽略该占位符。
0,如果在这个位置没有数字输入时,则Access显示0。
#如果在这个位置没有数字输入时,Access将忽略该占位符
16.在本实验的定义“日期/时间”型字段格式时,一个m或d与两位的mm或dd在使用时有何区别?
用“\”符号的作用是什么?
若设计格式为:
dddddd[红色],有何区别?
答:
一个d或m用于把某天或月份显示成一位或两位数字。
两位的mm或dd用于把某月份或天显示成固定的两位数。
“\”用于将其后跟随的第一个字符原文照印。
dddddd[红色]用于显示“长日期”格式,并显示为红色。
17.定义“输入掩码”属性的实质意义是什么?
在定义“学号”字段的输入掩码时,不使用“0”而使用“9”或“#”有和区别?
如果在“姓名”字段上必须定义10位输入掩码,那么应该定义什么掩码字符串?
答:
其作用为:
一、定义数据的输入格式;二、输入数据的某一位上容许输入的值的集合。
当使用“9”时,数字(0,9)或空格可以输入到该位置,不允许输入“+”和“-”符号。
如果在该位置没有输入任何数字或空格,Access将忽略该占位符。
“#”,数字,空格,“+”和“-”符号都可以输入到该位置,如果在该位置没有输入任何数字,则Access认为输入的是空格。
应该定义为9999999999.
18.可以采用查阅方法输入的字段类型有哪些?
绑定查阅列表框控件进行输入,如果不点击其中的值,而是输入不同的值,是否可以输入?
如果一定要使输入的值限定在列表框的值的范围内,应该如何实现?
答:
表/查询下值列表字段列表可以采用查阅方法输入的字段类型有“文本”、“是/否”和“数字”型。
无法输入。
在设置“行来源”时,在“值列表”里输入的值限范围扩大到包括输入的值限。
19.若在“课程”表删除“数据库及应用”记录,会发生什么现象?
什么含义?
答:
会弹出提示“不能删除”的对话框。
因为“课程”表已经与其他的表建立了关系,所以修改表结构会受到一定的限制。
要想删除被关系表引用的字段,那么Access提示删除前必须先解除关系,否则将不允许删除
20.在数据表浏览展开子表时,可以最多展开多少层子表?
若要同时展开每条记录的的子表,应该如何操作?
答:
8层。
可选择“格式”菜单下“子数据库”菜单项中的“全部展开”项
(二)实验项目2
1.有哪几种方式可进入“SQL视图”?
如果用“记事本”编写了SQL语句,是否可以在SQL视图中使用?
如何操作?
答:
①在查询对象列表窗口中双击“使用向导创建查询”,或者选中“简单查询向导”并单击“确定”按钮,将进入“简单查询向导”界面。
②双击“在设计视图中创建查询”,或者选中“设计视图”并单击“确定”按钮。
可以。
只需将编写的SQL语句剪切或复制再粘贴到SQL视图设计的命令上,要注意标点符号是英文状态下的。
2.为什么不能在数字常量前加“¥”或“$”符号表示币值常量?
“¥”或“$”有何作用?
答:
Access事先规定了数字运算符用来对数字型或货币型数据进行运算,运算的结果也是数字型数据或货币型数据。
“¥”或“$”用来表示货币的单位,在定义“货币“型字段的”格式“属性中使用
3.如果在修改“法学院”学分的操作中要求根据“学院名”作为输入条件修改数据,查询命令应该如何写?
答:
Update课程
Set学分=学分+1
Where学院号in(select学院号from学院where学院名=”法学院”)
4.不保存查询,与将查询保存为查询对象有何区别?
查询对象有什么作用?
答:
前者查询设计没有保存,再次使用时需要重新输入命令,后者当选中相应的查询对象并打开时,可直接运行查询查看结果。
作用:
①当需要查看查询结果时,直接在查询对象界面选中相应的查询对象并打开,就可以运行查询查看结果,避免了再次重新设计查询的操作。
并且查询对性总是获取数据源表中最新的数据。
查询能自动与源表保持同步。
②查询对象可以成为其他操作的数据源。
5.根据以下给定的查询要求,写出对应的查询命令。
①查询学生中的民族来源,显示不重复的民族数据。
答:
Selectdistinct民族
From学生
②查询各民族男生和女生的人数。
答:
Select民族,count(民族)as人数
From学生
Groupby民族,性别
③查询没有学生选修的课程信息以及开课的学院名。
答:
Select课程.*,学院.学院名
From课程innerjoin学院on课程.学院号=学院.学院号
Where课程号notin(select课程号from成绩)
④插入几条教师记录。
答:
Insertinto教师
Values(工号,姓名,性别,生日,职称,基本工资,学院号)
⑤给“教授”职称的教师的基本工资增加10%。
答:
Update教师
Set工资=工资*1.1
Where职称like“*教授”
⑥删除没有学生就读的专业数据。
答:
Deletefrom专业
Where专业号notin(select专业号from学生)
⑦删除教师表。
答:
Droptable教师
6.深入体会交叉表查询的作用,简述交叉表查询的实质意义。
作为行标题的字段最多可以设置几个?
作为列标题和交叉值的字段最多可以设置几个?
答:
交叉表查询是一种特殊的汇总查询。
交叉表的内容可以通过另外一种方式来输出显示。
可指定源表的一个或多个字段作为行标题,一个字段作为列标题,一个字段作为交叉值的来源。
7.参数查询的参数设置是否一定要通过菜单设置类型?
通过菜单设置的参数是否一定要出现在查询中?
答:
不是。
查询中可以不出现通过菜单设置的参数。
8.生成表查询实现的是SQL语言中什么语句的功能?
答:
该功能为实现SELECT语句中INTO子句的功能。
9.追加查询对应SQL的什么语句?
该语句是否只具有追加查询的功能?
若有其他功能,如何实现交互操作?
答:
对应SQL的INSERTINTO
是的
(三)实验项目3
1.什么是Access的外部数据?
答:
凡是不在当前Access数据库中存储,在其他数据库或程序中的数据就称为Access的外部数据。
2.简述不同软件进行数据导入、导出的意义。
答:
导入文件其实是外部文件以Access表文件格式存储为格式变化的数据备份,可以对外部文件进行一定的保护。
3.对于Access来说,导入和链接有什么异同点。
答:
同:
两者都是使用外部数据的方式。
异:
导入是指将其他应用程序中的数据移动到Access数据库中,它是对外部数据制作一个副本,并将副本移动到Access表中,在Access系统中使用。
链接是指与另一个Access数据库表或不同格式数据库里的数据建立链接。
它是以被链接数据的当前文件格式使用它,及保持原文件格式不变,在Access中使用外部数据。
4.在向文本文件导出时,怎样做到只导出数据而不导出字段名?
答:
在“导出文本向导”对话框2中取消“第一行包含字段名称”。
5.可以将表对象或查询对象导出,能否将外部数据导入为查询?
若要导入到查询,Access会怎样做?
答:
可以。
自动更改文件名以避免文件同名,在后来导入的文件名后面自动加了序号。
五、分析讨论
数据库是一门非常系统的课程,但是其中也有很多细节要注意。
而要将这些细节做好,需要花大量的时间和精力去钻研、学习和实践。
六、教师评语
1.按时完成实验;
2.实验内容和过程记录完整;
3.回答问题完整、正确;
4.有实验的心得或讨论;
5.实验报告的撰写认真、格式符合要求,没有抄袭行为。
签名:
日期:
2012.6
成绩
本实验的操作步骤如下:
实验项目一
(一)数据库与表的设计与创建
给定如下数据分析,进行概念设计与逻辑设计。
即设计系统的E-R模型并转换为关系模型。
E-R模型
学院
字段名
类型
宽度
小数
主键/索引
参照表
约束
Null值
学院号
文本型
2
↑(主)
学院名
文本型
16
院长
文本型
8
√
专业
字段名
类型
宽度
小数
主键/索引
参照表
约束
Null值
专业号
文本型
4
↑(主)
专业名
文本型
16
专业类别
文本型
8
↑
学院号
文本型
2
学院
学生
字段名
类型
宽度
小数
主键/索引
参照表
约束
Null值
学号
文本型
8
↑(主)
姓名
文本型
8
性别
文本型
2
男or女
生日
日期型
民族
文本型
6
↑
籍贯
文本型
20
专业号
文本型
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 及其 应用 实验 报告