《Access完整版课件全套ppt教学教程电子讲义电子教案(最新).ppt》由会员分享,可在线阅读,更多相关《Access完整版课件全套ppt教学教程电子讲义电子教案(最新).ppt(435页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、引语,数据库技术是20世纪60年代末兴起的一种数据管理技术。随着计算机技术的高速发展及信息时代的应用需求,数据管理技术已经融入到人们的日常工作和社会生活的各个领域,扮演着十分重要的角色。数据库技术也已成为计算机科学的重要分支。,第一节 数据库系统基础知识,1.信息与数据,信息(Information)与数据(Data) 一对既有联系、又有区别的基本概念。信息总是用数据来表示的;信息本身则来源于对现实世界客观事物的抽象。,现实世界与计算机世界的关系,1.1.1信息、数据和数据管理,现实世界中的两种事物,1. 具体的人或物,如一间教室、一台电脑、一个学生等 2. 抽象的概念,如年龄、体重、血型等,
2、客观事物反映到人们的头脑里,通过抽象就形成了信息,因此客观事物是信息的源泉。,事物的个体被称为实体,个体的特征称为属性; 拥有相同属性的实体称为同类实体,它们的集合则构成实体集。 在计算机中所有的信息均被抽象转换为计算机能接受的数据形式,并通过适当的软件对它们进行存储和管理。,客观事物,概念模型,选择、分类、命名,对客观事物进行定量记录的符号 如数量、年龄、考试成绩等,数值型,对客观事物进行定性记录的符号 如姓名、地址、毕业学校等,字符型,对客观事物进行形象特征和过程记录的符号如声音、图像、视频等,特殊型,数据表示信息有多种表现形式,2. 数据处理与数据管理,计算机是“数据自动处理机”,处理方
3、式:数据的获取、表示、存储、加工/计算、转换及查询等,处理目的:从大量的、杂乱无章的、难以理解的原始数据中抽取并推导出的对某些特定的人们来说是有价值的、有意义的数据,以此作为行为和决策的依据。,数据处理的最基本工作就是数据管理,(1)组织和保存数据 将收集到的数据合理分类组织,将其存储在物理载体上,使其能够长期保存 (2)进行数据维护 根据需要随时添加新数据、修改原有数据和删除无用或过时的数据 (3)提供数据查询和数据统计功能 提供数据查询和数据统计功能,以便快速地得到需要 的正确数据,数据库,数据库体现了当代先进的数据管理方式,主要研究与数据管理相关的技术。,1.1.2数据库技术的产生与发展
4、,数据管理的三个阶段,人工管理,文件管理,数据库管理,人工管理阶段,20世纪50年代中期以前 计算机主要用于科学计算。对数据管理,包括存储结构、存取方法、输入/输出方式等完全由程序设计人员负责,这一阶段称为人工管理阶段。 特点:数据不保存;由应用程序管理数据;数据不具有独立性也不具有共享性。,文件管理系统,20世纪50年代后期到60年代中期 计算机不仅用于科学计算,而且还大量用于事物管理。这一时期出现了可以直接存取的磁鼓和磁盘,它们成为联机的主要外部存储设备;同时软件方面,出现了高级语言和操作系统。操作系统中有了专门的数据管理系统,称为文件管理系统。 特点:数据可以长期保存在外部设备上;数据是
5、由文件系统来管理的;数据的独立性和数据的共享性较差,数据的冗余度较大。,数据库管理系统,20世纪60年代后期 随着计算机用于数据处理的规模越来越大而产生了数据库管理系统。数据库管理系统克服了文件管理系统阶段的缺陷,对相关数据进行统一规划管理、形成一个数据中心,构成一个数据“仓库”,实现了整体数据的结构化。 特点:数据整体结构化;具有很高的数据独立性;数据冗余度较低,共享性较强;数据由数据库管理系统统一管理和控制。,1.非关系数据模型(包括层次模型和网状模型),现代,3.面向对象数据模型,数据模型发展历程,2.关系数据模型,数据库发展阶段的划分是以数据模型的发展为主要依据的,第三代,非关系型 数
6、据库系统,数据库技术的发展,第二代,第一代,关系型 数据库系统,面对对象 数据库系统,第一代 非关系型数据库系统,非关系模型 数据库系统,层次模型,网状模型,单线联系,多线联系,1969年,美国IBM公司开发的层次模型数据库系统IMS(Information Management System)和20世纪70年代美国数据库系统语言协会CODASYL (Conference On Data System Language)的数据库任务组提出的网状模型数据库系统规范报告,简称为DBTG(Data Base Task Group)报告。,典型代表,第二代 关系型数据库系统,二维表 通过公共的关键字段
7、实现不同二维表(或“关系”)之间的数据联系。,1970年,美国IBM公司San Jose实验室的研究员科德(E.F.Codd)提出了关系模型的概念,关系型数据库(Relational Database System,简称RDBS)开始问世。关系模型是建立在数学概念基础上的,有着坚实的数学理论基础。20世纪80年代以来,计算机厂商推出的数据库管理系统绝大多数都支持关系模型,现在微机上使用的数据库系统几乎都是关系型数据库。,典型代表,第三代 面向对象 关系型数据库系统,80年代中期以来,对新一代数据库系统的研究日趋活跃,出现了包括分布式数据库系统、并行数据库系统和面向对象数据库系统等新型数据库系统
8、。随着多媒体应用的扩大,人们希望新一代数据库系统除存储传统的文本信息外,还能存储和处理图形、声音等多媒体对象,于是第三代数据库应运而生。将数据库技术与面向对象技术相结合,成为第三代数据库系统的发展方向。,对于中、小数据库用户而言,由于高级数据库系统的专业性要求太高,通用性受到一定的限制,在推广使用的范围上受到约束。而基于关系模型的关系数据库系统功能的扩展与改善,面向对象关系数据库、数据仓库、Web数据库、嵌入式数据库等数据库技术的出现,构成了新一代数据库系统发展的主流。,1.1.3数据库、数据库管理系统,1. 数据库 数据库(DataBase,简称DB)是长期存放在计算机存储设备上的,有组织、
9、可共享的数据集合。, 数据库把与应用程序相关的数据及其联系集中在一块并按照一定的结构形式进行存储,即数据库具有集成性; 数据库中的数据可以被多个用户和多个应用程序共享,即数据库具有共享性; 数据库的结构独立于程序,对于数据库的数据增加、删除、修改和检索等操作是由软件进行的,即数据库中的数据与程序具有较高的独立性。, 减少了数据的冗余(重复) 避免数据的不一致 易于使用、便于扩展 具有较高的数据安全性和完整性 支持多用户操作,2. 数据库管理系统 (DataBase Management System,DBMS),位于用户与操作系统之间,具有数据定义、操纵、查询和控制的系统软件,是数据库系统的核
10、心组成部分。,功能 (1)数据定义 包括定义构成数据库结构的模式、存储模式和外模式,定义外模式与模式之间的映射,定义模式与存储模式之间的映射,定义有关的约束条件。 (2)数据操纵 包括对数据库数据的检索、插入、修改和删除等基本操作。 (3)数据库运行管理 包括对数据库进行并发控制、安全性检查、完整性约束条件、数据库的维护等,以保证数据的安全性、完整性、一致性以及多用户对数据库的并发使用。,(4)数据组织、存储和管理 对数据字典、用户数据、存取路径等数据进行分门别类地组织、存储和管理,确定以何种文件结构和存取方式物理地组织这些数据,以便提高存储空间利用率以及缩短操作时间。 (5)数据库的建立和维
11、护 包括数据库初始数据的输入与数据转换等。 维护数据库包括数据库的转储与恢复、数据库的重组织与重构造、性能的监视与分析等。 (6)数据通信接口 提供数据库管理系统与其他软件进行通信的功能。例如提供与其他DBMS或文件系统的接口,从而能够将数据转换为另一个DBMS或文件系统能够接受的格式。,在现实世界中,经常用模型来模拟和抽象事物的主要特征。模型能够清楚地表示某一事物。客观世界中的事物反映在人们的头脑中称为概念世界。在概念世界中将客观事物及其性质常抽象为实体及属性。由于概念世界中的信息在计算机中只能以数据形式存储,因此人们必须事先把具体事物转换成计算机能够处理的数据。在数据库中用数据模型来模拟、
12、抽象、逼近和表示现实世界中的数据和信息。,第二节 数据模型,容易被人理解,能够比较真实地模拟现实世界,便于在计算机系统中实现,要,求,数据模型(Data Model) 现实世界数据特征的抽象,数据结构,数据操作,数据约束条件,数据模型的三要素,常见数据模型:,数据模型是数据库系统的核心和基础,各种机器上实现的DBMS软件都是给予某种数据模型的。,1.2.1实体模型(Entity Model),在信息世界中,客观存在并可以相互区分的客观事物或抽象事件称作实体(Entity),Concept,客观存在并且可以相互区分的客观事物或抽象事件。,实体有若干特性,每个特性称作实体的一个属性。,能唯一标识实
13、体的一个属性或属性集称作码或关键字。,属性取值范围称为该属性的域。,具有相同属性的实体必然具有共同的特征和性质。,实体集是若干个同类实体的集合。,1.有关实体模型的几个概念,2. 实体之间的联系 实体之间的对应关系称为关联,它反映现实世界事物之间的相互联系。在信息世界中,联系是指实体与实体之间、实体集内的实体与实体之间以及组成实体的各属性间的关系。,3. E-R模型 P.P.S.Chen于1976年提出的“实体-联系模型(Entity-Relationship Approach)”,简称E-R模型。 E-R模型中,常用E-R图来描述。在E-R图中,图形要素是矩形框、椭圆和菱形框。,01,02,
14、03,能真实自然地描述现实世界,图形元素简单直观,易为用户和设计者理解和交流,容易向其他数据模型转换,E-R图的优点,(1)对现实世界进行分析,抽象以后,找出实体集及其属性;,(2)找出实体集之间的联系;,(3)找出实体集联系的属性;,(4)绘制E-R图。一般是先绘制局部的E-R图,然后再绘制全局的E-R图。,画E-R图的基本步骤:,在信息世界中,实体的属性也叫字段(Filed),也称作数据项;字段名往往和属性名相同。例如教师的字段有教师号、教师姓名、所属学院、身份证号、性别、学历、职称、专业、工龄等。 字段的有序集合称作记录(Record)。现实世界中的实体及其联系,在计算机世界中用数据模型
15、来表示。,1.2.2层次模型(Hierarchical Model),现实世界中,许多实体之间的联系呈现出一种自然的隶属或层次关系,例如行政机构、家族等。因此,可用树型结构表示各类实体及实体间的联系。在层次模型中每个结点表示一个实体型,结点之间的连线表示实体型间的联系,这种联系是“父子”结点之间的“一对多”的联系。,高校教学层次模型,(1)层次模型只有一个无父结点,这个结点称为根结点。,(2)根节点以外的其他结点仅有一个父结点。,特,征,1.2.3网状模型 (Network Model),在现实世界中,事物之间的关系大多数是非层次关系,如果用层次模型描述这种关系就有一定的困难,因此,引入了网状
16、模型。 网状模型是层次模型的扩展,它表示多个从属关系的层次结构,呈现一种交叉关系的网络结构,网状模型是有向“图”结构,如图1.3所示。在网状模型中,每一个结点表示一个实体型,结点之间的连线表示实体型间的联系,从一个结点到另一个结点用有向线段表示,箭头指向“一对多”的联系的“多”方。,学校管理的网状模型,(1)网状模型允许一个以上的结点无父结点。,(2)允许结点有多于一个的父结点。,特,征,1.2.4关系模型 (Relational Model),虽然网状模型比层次模型更有普遍性,但是由于其结构比较复杂,不便于应用程序的实现。因此,新的数据模型-关系模型便应运而生,关系模型是最重要的一种数据模型
17、。 关系数据库系统采用关系模型作为数据的组织形式。现在主流数据库大都是基于关系模型的数据库系统。 关系模型是由美国IBM公司的研究员E.F.Codd于1970年首次提出的。为了表彰E.F.Codd为关系数据库技术做出的杰出贡献,1981年的图灵奖授予了这位“关系数据库之父”。,学生关系表,1.关系模型的常用术语 (1)关系(Relation) 一个关系对应一张二维表,每个关系都有一个名称即关系名,表示为R(D1,D2,Dn),其中R为关系名,D1,D2,Dn为属性名。在Access数据库中,一个关系存储为一个表,具有一个表名。 对关系的描述称为关系模式,一个关系模式对应一个关系的结构。其格式为
18、: 关系名(属性名1,属性名2,属性名n) 在Access中,表示为表结构:表名(字段名1,字段名2,字段名n) (2)元组(Tuple) 在一个二维表(一个具体关系)中,一行称为一个元组,对应表中的一个具体记录。 (3)属性(Attribute) 二维表中的一列称为一个属性,每一个属性有一个名称即属性名,与前面讲的实体属性相同。在Access中表示为字段名。例如表1.1中有五列,则有五个属性名(学生编号,姓名,性别,出生年月,学生班级)。,(4)域(Domain) 属性的取值范围,称为域。即不同元组对同一个属性的取值所限定的范围。表1.1中性别值域是男,女。 (5)主码或主关键字(Prima
19、ry Key) 表中能够唯一地标识一个元组的属性或元组属性的组合称为主码或主关键字。它可以唯一地确定关系中的一个元组。在Access中能够唯一标识一条记录的字段或字段组合,也称为主键。表1.1中由于学生编号具有唯一性,故可以作为标识一条记录的关键字。由于可能有重名的学生,所以,姓名字段不能作为主关键字,但姓名字段和出生年月字段的组合一般可以唯一标识一个记录,因此可以作为主关键字。 (6)外部关键字(Foreign Key) 如果表中的一个字段不是本表的主关键字,而是另外一个表的主关键字,这个字段(属性)就称为外部关键字。在Access中称为外键。,(1)每一列中各数据项具有相同属性,即同一列的
20、数据必须是同一数据类型。,(2)每一行代表一个实体,任何两行的值不能完全相同。,(3)每一行中由一个实体的多种属性构成。,(4)行与行、列与列的次序可以任意交换,且不改变关系的实际意义。,(5)关系中每一个数据项不可再分,也就是说不允许表中还有表。,2.关系模型的5条性质,E.F.Codd的规定,如下课程表,其属性为课程编号、课程名称、学时,这时就不能正确反映实际情况;因为学时还可以再分为理论学时和实验学时才能反映实际情况。因此课程关系的属性应该为课程编号、课程名、理论学时和实验学时。,课程表,1.2.5面向对象模型 (Object Oriented Model),由于现实世界存在着大量的、复
21、杂的、不规范的数据,需要对其进行复杂的数据处理,而传统的数据模型不能适应新一代数据库应用的需求,因此需要更高级的数据模型来表达,面向对象模型便孕育而生。 面向对象的概念最初出现在程序设计中,因为更便于描述复杂的客观现实,所以迅速渗透到计算机的其他领域。面向对象模型是面向对象概念与数据库技术相结合的产物。,面向对象模型最基本的概念是对象(Object)和类(Class)。 在面向对象模型中,对象是指某一客观的事物,对象的描述具有整体性和完整性,对象不仅包含描述它的数据,而且还包含对它进行操作的方法,对象的外部特征与行为是紧密联系在一起的。其中,对象的状态由一组属性值组成,是该对象属性的集合;对象
22、的行为由一组方法组成,是在对象状态上操作的方法的集合。共享同一属性集和方法集的所有对象构成了类。,1.2.5面向对象模型 (Object Oriented Model),1.2.5面向对象模型 (Object Oriented Model),面向对象模型是用“面向对象”的观点来描述现实世界客观存在的逻辑组织、对象间联系和约束的模型。它能完整地描述现实世界的数据结构,具有丰富的表达能力。由于该模型相对比较复杂,涉及的知识比较广,因此尚未达到关系模型的普及程度。,1970年,IBM公司研究员E.F.Codd在美国ACM通信上发表了题为“大型共享数据库的关系模型”论文,率先提出了以二维表的形式(Co
23、dd称之为“关系”)来组织数据库中的数据,提出了关系数据模型的思想,奠定了关系数据库系统坚实的基础。“关系”原本是一个数学概念,其理论基础是集合代数。关系方法就是采用数学方法来处理数据库中的数据。关系数据库是目前效率最高的一种数据库系统。Access就是基于关系模型的数据库系统。,背景,第三节 关系数据模型,1.3.1 关系数据结构,关系操作集合,关系数据结构,关系完整性约束,关系模型,1.3.2 关系运算,关系运算采用集合运算方式,即运算的对象和结果都是集合。 这种运算方式也称为一次一集合(Set-at-a-time)的方式。相应地,非关系数据模型的数据操作方式则为一次一记录(Record-
24、at-a-time)的方式。,查询运算是关系运算中的最主要部分,包括选择(Select)、投影(Project)、连接(Join)、除(Divide)、并(Union)、交(Intersection)、差(Difference)等。,关系运算,查询,更新,选 择,投 影,并,差,笛卡儿积,其他运算可以通过基本运算来定义和导出,1.选择 选择是对一个关系表中的记录进行的选择,该运算可以把符合某个条件的记录集选择出来,重新构建一个原表的子表。用于在关系表的水平方向(行)选择符合给定条件的元组。 2.投影 投影是对一个关系表中的字段进行的选择,该运算可以消去表的某些字段,并按要求重新安排次序。用于在
25、关系表的垂直方向(列)找出含有给定属性列(或属性组)的子集。 3.连接 连接运算是将两个关系表,按照两个关系表中相同字段间的一定条件选择记录子集。连接运算属二元运算,参加运算的有两个关系表,结果生成一个新的关系。,关系数据库中最常用的3种关系运算,关系运算可用代数方式或逻辑方式表示。关系代数是用关系的运算方式来表达查询的要求;关系演算是用谓词的方式来表达查询要求。关系数据语言有关系代数语言(例如ISBL)、关系演算语言(例如元组关系语言ALPHA和QUEL)以及具有关系代数和关系演算双重特点的语言(例如SQL)。,更新运算包括增加(Insert)、删除(Delete)和修改(Update)等。
26、,1.关系完整性:为保证数据库中数据的正确性和相容性而对关系模型提出的某种约束条件或规则。例如学校的数据库中规定性别只能为男或女,成绩只能为0100或者“优”、“良”、“中”、“及格”或“不及格”等。,2.关系模型的操作必须满足关系的完整性约束条件。,1.3.3关系完整性约束,3.关系的完整性约束条件包括用户定义的完整性、实体完整性和参照完整性三种。,(1)用户定义完整性(User-defined Integrity) 用户定义完整性则是根据应用环境的要求和实际的需要,对某一具体应用所牵涉的数据提出约束性条件。具体的说就是所涉及的数据必须满足一定的语义要求。例如某个属性必须取唯一值、某个属性不
27、能取空值(Null)、某个属性的取值范围在0100之间等。用户定义完整性主要包括字段有效性约束和记录有效性约束。用户定义完整性是针对某一具体关系数据库的约束。关系模型应提供定义和检测这类完整性的机制。,注:其中Null为“空值”,即表示未知的值,是不确定的。,(2)实体完整性(Entity Integrity) 实体完整性是对关系中元组的唯一性约束,也就是对主关键字的约束,即关系(表)的主关键字不能是空值(Null)且不能有重复值。 设置实体完整性约束后,当主关键字值为Null(空)时,关系中的元组无法确定。例如在Student表关系中,“StudentID”是主码,由它来唯一识别每位学生,如
28、果它的值取空值,将不能区分具体的学生,这在实际的数据库应用系统中是无意义的;当不同元组的主关键字值相同时,关系中就自然会有重复元组出现,这就违背了关系模型中元组的唯一性原则,因此这种情况是不允许的。,注:在关系数据库管理系统中,一个关系只能有一个主关键字,系统会自动进行实体完整性检查。,(3)参照完整性(Referential Integrity) 参照完整性是对关系数据库中建立关联的关系之间数据参照引用的约束,也就是对外部关键字的约束。具体来说,参照完整性是指关系中的外部关键字必须是另一个关系的主关键字的值,或者是Null。,例如,已知关系“Student表”(见表1.3),与关系“Stud
29、entCourse表”(见表1.4),在关系“Student表”中“StudentID”为主关键字; 在关系“StudentCourse”中“StudentID”为外部关键字。则在关系“StudentCourse表”中“StudentID”属性的取值只能是关系“Student表”中某个“StudentID”的值,或者取Null值。,表1.3 Student表,表1.4 StudentCourse表,关系完整性约束是关系设计的一个重要内容,关系的完整性要求关系中的数据及具有关联关系的数据间必须遵循的一定的制约和依存关系,以保证数据的正确性、有效性和相容性。其中实体完整性约束和参照完整性约束是关系
30、模型必须满足的完整性约束条件。 关系数据库管理系统为用户提供了完备的实体完整性自动检查功能,也为用户提供了设置参照完整性约束、用户定义完整性约束的环境和手段,通过系统自身以及用户定义的约束机制,就能够充分地保证关系的准确性、完整性和相容性。,1.3.4关系的规范化,在数据库设计中,一个非常重要的问题是怎样把现实世界表示成合适的数据库模式。关系数据库的规范化理论就是进行数据库设计的有力工具。,关系数据库中的关系(表)要满足一定要求,满足不同程度要求的为不同范式。遵循的主要范式有第一范式(1NF)、第二范式(2NF)、第三范式(3NF)和第四范式(4NF)等。 规范化设计的过程就是按不同的范式,将
31、一个二维表不断地分解成多个二维表并建立表间的关联,最终达到一个表只描述一个实体或者实体间的一种联系的目的。 其目标是减少数据冗余,提供有效的数据检索方法,避免不合理的插入、删除、修改等操作,保持数据一致,增强数据的稳定性、伸缩性和适应性。,(1)第一范式 在关系模型的5条性质中提到,关系中每一个数据项是不可再分的,满足这个条件的关系模式就属于第一范式。关系数据库中的所有关系都必须满足第一范式。,例如将表1.5“课程表”规范为满足第一范式的表。显然表1.5 “课程表”不满足第一范式。处理方法是将表头改为只有一行标题的数据表,见表1.6。,表1.5 课程表,表1.6 满足第一范式的课程表,(2)第
32、二范式 在满足第一范式的关系中,如果所有非主属性都完全依赖于主码,则称这个关系满足第二范式。即对于满足第二范式的关系,如果给定一个主码,则可以在这个数据表中唯一确定一条记录。一个关系模式如果不满足第二范式,就会产生插入异常、删除异常、修改复杂等问题。,例如表1.7的“学生课程综合数据表”,在表中没有哪一个数据项能够唯一标识一条记录,则不满足第二范式。,表1.7 学生课程综合数据表, 冗余度大。一个学生如果选了n门课程,则他的有关信息就要重复n遍,这就造成数据的极大冗余。 插入异常。在这个数据表中,如果要插入一门课程的信息,但此课程没有学生选修,则很难将其插入表中。 删除异常。表中李佳如只选修了
33、一门课程“数据结构”,如果她不选了,这条记录就要被删除即整个元组都随之删除,使得她的所有信息都被删除了,从而造成删除异常。,该数据表存在如下缺点:,表1.8 学生选课表,表1.9 学生专业表,表1.10 课程表,处理表1.7使之满足第二范式的方法是将其分解成三个数据表,见表1.8、表1.9、表1.10。这三个表均满足第二范式。其中“学生选课表”的主码为“学号”和“课程编号”的组合,“学生专业表”的主码为“学号”,“课程表”的主码为“课程编号”。,(3)第三范式 对于满足第二范式的关系,如果每一个非主属性都不传递依赖于主码,则称这个关系满足第三范式。传递依赖就是某些数据项间接依赖于主码。在表1.
34、10课程表中,性别属于课程负责人,主码“课程编号”不直接决定非主属性“性别”,“性别”是通过课程负责人传递依赖于“课程编号”的,所以此关系不满足第三范式。在某些情况下,不满足第三范式的关系会存在插入、删除异常和数据冗余等现象。为了将此关系转化为满足第三范式的数据表,可以将其分成表1.11 “课程表”和表1.12 “课程负责人表”。经过规范化处理,满足第一范式的“学生课程综合数据表”被分解为满足第三范式的四个数据表(学生选课表、学生专业表、课程表、课程负责人表)。,表1.11 课程表,表1.12 课程负责人表,在对数据库进行规范设计时,应该保证所有数据表都能满足第二范式,尽量满足第三范式。除上述
35、的三种范式外,还有BCNF(Boyce Codd Normal Form)、第四范式、第五范式。对于一个低一级范式的关系,可以通过模式分解,规范化为若干个更高一级范式的关系集合。,本章小结,信息是经过处理的有用数据,数据处理的目的是得到信息,数据处理的核心问题是数据管理。数据管理技术经历了人工管理、文件管理和数据库系统三个阶段。 数据模型是数据库系统的核心,数据模型包括:数据结构、数据操作和数据约束条件三个方面。常用的数据模型有:层次模型、网状模型、关系模型和面向对象模型。关系模型是最重要的一种数据模型。关系模型数据库中最常用的三种关系运算是选择、投影和连接。关系模型完整性约束条件包括用户定义
36、完整性、实体完整性和参照完整性三种。,第二章 Access系统概述,第一节 Access关系数据库 第二节 Access的数据库对象 第三节 Access的启动与退出 第四节 Access的工作环境 第五节 本章小结,Access 是Windows 环境下的关系型数据库管理软件。它提供了大量的工具和向导,即使没有任何编程经验,也可以通过可视化的操作来完成大部分的数据库管理和开发工作。而对于数据库的开发人员,Access提供了VBA(Visual Basic for Application)编程语言,可用于开发高性能、高质量的桌面数据库系统。,第一节 Access关系数据库,从Access1.0
37、 的诞生到目前Access 2003 都得到了广泛的应用。Access经历了多次的升级,其功能越来越强大,操作也越来越简单。,Access 2003是Microsoft公司推出的面向办公自 动化、功能强大的关系数据库管理系统,是 Microsoft Office 系列应用软件的一个重要组成部 分,是目前最普及的关系数据库管理软件之一。,2.1.1 Access关系数据库,Access操作简单,易学易用。Access 2003对以前的Access版本作了许多的改进,其通用性和实用性大大增强,集成性和网络功能更加强大。 Access是一种关系数据库管理系统(RDBMS)。顾名思义,关系数据库管理系
38、统是数据库管理软件,它的职能是维护数据库、接受和完成用户提出的访问数据的各种请求。利用Access可以对已有的数据库进行操作,也可以在此基础上进行数据库的开发和设计。,2.1.2 Access的版本,自从1992年11月正式推出Access 1.0以来,Microsoft公司一直在不断地完善增强Access的功能,1994年推出的Access 2.0有了较大的改动,75%以上的内容都是新增或改进的。 1995年随着Windows 95的推出,Microsoft公司又将Access 2.0升级为Access 7.0,1997年推出了Access 97,Microsoft首次对Access 97进
39、行了汉化,推出了Access 97 中文版,随后又推出了中文版的Access 2000、 Access 2002和Access 2003。,2.1.3 Access的特点,Access为用户提供了友好的用户界面和方便快捷的运行环境。Access 2003数据库管理系统不仅具有传统的数据库系统的功能,同时还进一步增强了自身的特性。 (1)Access是一个中、小型关系数据库管理系统,适合于开发中、小型管理信息系统。 (2)Access作为Microsoft Office组件中的一个数据库管理软件,可能对数据进行处理、查询和管理。它与Excel、Word、PowerPoint等应用程序具有统一的操
40、作界面,并可数据共享。 (3)采用OLE技术,能够方便创建和编辑多媒体数据库,包括文本、声音、图像和视频。 (4)Access支持ODBC标准的SQL数据库的数据。,(5)Access内置了大量的函数,其中包括数据库函数、算术函数、文本函数、日期时间函数、财务函数等,用户利用它可以解决许多问题而不必编写代码。 (6)Access提供了许多宏命令。宏命令在用户不介入的情况下能够执行许多常规的操作。用户只要按照一定的顺序组织Access提供的宏操作,就能够实现工作的自动化 。 (7)Access内置编程语言Visual Basic(VB),提供使用方便的开发环境VBA(Visual Basic f
41、or Application)窗口,允许用户通过编程的方式完成较复杂的任务,VBA大加强了Access的应用系统开发能力。,第二节 Access的数据库对象,Access关系数据库是数据库对象的集合。数据库对象包括:表(Table)、查询(Query)、窗体(Form)、报表(Report)、页(Page)、宏(Macro)和模块(Module)。,图2.1 Access数据库窗口,在任何时刻,Access只能打开并运行一个数据库。但是,在每一个数据库中,可以拥有众多的表、查询、窗体、报表、页、宏和模块。这些数据库对象都存储在同一个以.mdb为扩展名的数据库文件中。一个Access 2003数
42、据库就是一个扩展名为.mdb的文件。,下面我们对 Access数据库中的7个对象做简单的介绍:,1表(Table) 在Access关系数据库中,表是有结构的数据的集合,是数据库应用系统的数据“仓库”。表用于存储基本数据。 表示存储数据的基本单元,每个表都拥有自己的表名和结构。表由不同的列、行组合而成,即由行和列组成的二维表格。在表中,一行数据称为一条记录,每一列代表某种特定的数据类型,称为一个字段。 在Access关系数据库中,有关表的操作都是通过表对象来实现的。表对象可以管理表的结构(包括字段名称、数据类型、字段属性等)以及表中存储的记录。 用于显示和编辑表结构的窗口称为设计视图。用于显示、
43、编辑和输入记录的窗口称为数据表视图 。如图2.2和2.3所示。,图2.2 Student数据表的设计视图,图2.3 Student数据表视图,2查询(Query) 查询就是按照一定的查询条件或准则,对数据表和已建立的查询数据进行查找。查询提供了另外一种浏览数据表的方式。通过查询用户可以依据准则或查询条件抽取表中的记录与字段。查询到的数据记录集合称为查询的结果集,它与表一样,都是数据库的对象,但它不是基本表。 在Access中,查询主要包括选择查询、参数查询、交叉表查询、操作查询和SQL查询等。其中操作查询又包括删除查询、追加查询、更新表查询和生成表查询。在查询中,重要的是设置查询条件,以便获取
44、所需要的数据。,图2.4 利用Student数据表建立的查询,3窗体(Form) 窗体是Access数据库的用户界面,是用户与Access数据库应用程序交互的主要接口,是应用最为广泛的数据库对象。在Access中,有关数据输入、编辑、显示和查询等都是通过窗体对象来实现的。窗体对象允许用户采用可视化的直观操作设计数据输入、输出界面以及应用系统控制界面的结构和布局。通过窗体,使得用户对数据库的操作更加简单。,窗体还提供了一个良好的数据库编程环境,用户可以通过宏命令或VBA 代码对窗体、报表、Web页等应用接口的各种对象编程处理,以使其完成更加复杂的任务。,图2.5 “教学管理”数据库中Teache
45、r数据表窗体,4报表(Report) 在Access关系数据库中,报表对象允许用户不用编程仅通过可视化的直观操作就可以设计报表打印格式。与窗体不同,报表不能用来输入数据。报表对象不仅能够提供方便快捷、功能强大的报表打印格式,而且能够对数据进行分组统计和计算。,图2.6 “教学管理”数据库中Student报表,5页(Page) 页也称数据访问页,是自Access2000之后新增的对象,指的就是网页(Web Page)。通过页可以将数据库中的记录发布到Internet或Intranet,并使用浏览器进行记录的维护和操作。 页是用于在Internet或Intranet上浏览的Web页。页可以用来输入
46、、编辑、浏览Access数据库中的记录。,图2.7 “教学管理”数据库中Student数据访问页,6宏(Macro) 宏是一个或多个操作的集合。其中的每一个操作执行特定的单一数据库操作功能,如打开窗体、生成报表等。在日常工作中,用户经常需要重复大量的操作,利用宏就可以简化这些操作,使大量的重复性操作能自动完成。 Access提供了许多宏操作,这些宏操作可以完成日常的数据库管理工作。,图2.8 “教学管理”数据库的宏对象窗口,7模块(Module) 模块是一个用VBA(Visual Basic for Application)语言编写的程序段,是由声明、语句和过程组成的集合。模块中的每一个过程可
47、以是一个函数过程,也可以是一个子过程。通过将模块与窗体、报表等Access对象相联系,可以建立完整的数据库应用程序。 模块的主要作用是建立VBA程序以实现宏等难以完成的较为复杂或高级的功能。使用VBA语言的目的主要有两个:一是创建在窗体、报表和查询中使用的自定义函数;二是提供在所有类模块中都可以使用的公共子过程。通过在数据库中添加的VBA代码,可以创建出自定义菜单、工具栏和具有其他功能的数据库应用系统。,作为Microsoft Office 套件的成员Access 2003的使用界面与Word、Excel等的风格相同。在Access 中编辑数据库对象就像在Word中编辑文档、Excel中编辑表
48、一样方便。其强大的功能和详尽的帮助,使读者可以在较短的时间里,做出一个具有Windows风格的数据库应用系统。,第三节 Access的启动与退出,2.3.1 启动Access,启动Access的方法与启动其他Office软件完全一样,常用以下三种方式。 (1)从“开始”菜单启动。在Windows任务栏中,依次单击“开始”|“程序”|“Microsoft Office”|“Microsoft Office Access 2003”。 (2)使用快捷方式启动。双击桌面上的Access 2003快捷方式图标,即可启动Access。 (3)打开文件方式。双击一个已建立好的Access文件,系统会先启动
49、Access程序,再在此程序窗口中打开指定的文件。,2.3.2 关闭Access,若要退出Access,可以采用以下四种方法: (1)从“文件”菜单中选择“退出”命令。 (2)单击Access应用程序窗口右上角的“关闭”按钮。 (3)双击Access应用程序窗口左上角的应用程序控制菜单图标。 (4)按Alt+F4组合键。,第四节 Access的工作环境,Access 2003的工作窗口主要由标题栏、菜单栏、工具栏、数据库窗口、状态栏和任务窗格组成。如图2.9所示。,图2.9 Access工作窗口,2.4.1 菜单栏,Access的菜单栏中共有7个默认菜单,如图2.10所示。单击菜单栏中的菜单名,将打开对应的下拉菜单。选择下拉菜单中的命令,将执行该命令指定的操作。 Access的菜单栏为用户使用Access命令提供了便捷的途径。 Access的菜单栏完全遵循Windows对菜单的有关规范。,图2.10 Access 2003菜单栏,2.4.2 工具栏,Access工具栏上的每一个命令按钮对应于一条菜单项命令。用户通过单击工具栏上的命令按钮快速执行常用的操