VFP数据库系统.ppt
1,Visual foxpro 语言,主讲:余虹,长沙理工大学经管学院,2,1.1 数据管理技术的发展1.2 数据库系统1.3 数据模型1.4 关系数据库1.5 Visual FoxPro系统简介1.6 Visual FoxPro操作基础1.7 项目管理器1.8 VFP的文件类型,第一章 数据库系统基础知识,3,1.1 数据管理技术的发展,1.1.1 数据与数据处理1.数据和信息2.数据处理1.1.2 数据管理技术1.人工管理阶段2.文件系统阶段3数据库系统阶段(1)分布式数据库系统(2)面向对象数据库系统(3)多媒体数据库系统(4)数据仓库,4,1.1.1 数据与数据处理1.数据和信息 数据是人们用于记录事物情况的物理符号。为了描述客观事物而用到的数字、字符以及所有能输入到计算机中并能被计算机处理的符号都可以看作数据。有两种基本形式的数据:数值型数据、字符型数据。此外,还有图形、图像、声音等多媒体数据。,5,信息是数据中所包含的意义。通俗地讲,信息是经过加工处理并对人类社会实践和生产活动产生决策影响的数据。数据与信息既有区别,又有联系。数据是表示信息的,但并非任何数据都能表示信息,信息只是加工处理后的数据,是数据所表达的内容。另一方面信息不随表示它的数据形式而改变,它是反映客观现实世界的知识,而数据则具有任意性,用不同的数据形式可以表示同样的信息。,6,数据处理是指将数据转换成信息的过程。它包括对数据的收集、存储、分类、计算、加工、检索和传输等一系列活动。其基本目的是从大量的、杂乱无章的、难以理解的数据中整理出对人们有价值、有意义的数据(即信息),作为决策的依据。,2.数据处理,7,1.1.2 数据管理技术,1.人工管理阶段 20世纪50年代中期以前,计算机主要应用于科学计算,数据量较少,一般不需要长期保存数据。硬件方面,没有磁盘等直接存取的外存储器。软件方面,没有对数据进行管理的系统软件。在此阶段,对数据的管理是由程序员个人考虑和安排的,他们既要设计算法,又要考虑数据的逻辑结构、物理结构以及输入输出方法等问题。程序与数据是一个整体,一个程序中的数据无法被其他程序使用,因此程序与程序之间存在大量的重复数据。数据存储结构一旦有所改变,则必须修改相应程序。应用程序的设计与维护负担繁重。,8,2.文件系统阶段 20世纪50年代后期至60年代后期,计算机开始大量用于数据管理。硬件上出现了直接存取的大容量外存储器,如磁盘、磁鼓等,这为计算机系统管理数据提供了物质基础。软件方面,出现了操作系统,其中包含文件系统,这又为数据管理提供了技术支持。文件系统提供了在外存储器上长期保存数据并对数据进行存取的手段。文件的逻辑结构与存储结构有一定区别,即程序与数据有一定的独立性。数据的存储结构变化,不一定影响到程序,因此程序员可集中精力进行算法设计,并大大减少了维护程序的工作量。,9,文件系统使计算机在数据管理方面有了长足的进步。时至今日,文件系统仍是一般高级语言普遍采用的数据管理方式。然而当数据量增加、使用数据的用户越来越多时,文件系统便不能适应使用数据的需要了,其症结表现在3个方面:(1)数据的冗余度大。由于数据文件是根据应用程序的需要而建立的,当不同的应用程序所需要使用的数据有许多部分相同时也必须建立各自的文件,即数据不能共享,造成大量重复。这样不仅浪费存储空间,而且使数据修改变得非常困难,容易产生数据不一致,即同样的数据在不同的文件中所存储的数值不同,造成矛盾。,10,(2)数据独立性差。在文件系统中,数据和应用程序是互相依赖的,即程序的编写与数据组织方式有关,如果改变数据的组织方式,就必须修改有关应用程序。这无疑将增加用户的负担。此外,数据独立性差也不利于系统扩充、系统移植等开发推广工作。(3)缺乏对数据的统一控制管理。在同一个应用项目中的各个数据文件没有统一的管理机构,数据完整性和安全性很难得到保证。数据的保护等均交给应用程序去解决,使得应用程序的编制相当繁琐。较好地解决文件系统存在的问题,正是数据库系统的目标。,11,3数据库系统阶段 20世纪60年代后期,计算机在管理中应用规模更加庞大、数据量急剧增加,数据共享性更强。硬件价格下降,软件价格上升,编制和维护软件所需成本相对增加,其中维护成本更高。这些成为数据管理在文件系统的基础上发展到数据库系统的原动力。在数据库系统中,由一种叫做数据库管理系统(DBMS:Database Management Systems)的系统软件来对数据进行统一的控制和管理,从而有效地减少了数据冗余,实现了数据共享,解决了数据独立性问题,并提供统一的安全性、完整性和并发控制功能。,12,数据库是在数据库管理系统的集中控制之下,按一定的组织方式存储起来的、相互关联的数据集合。在数据库中集中了一个部门或单位完整的数据资源,这些数据能够为多个用户同时共享,且具有冗余度小、独立性和安全性高等特点。,13,数据库技术的发展先后经历了层次数据库、网状数据库和关系数据库。层次数据库和网状数据库可以看作是第一代数据库系统,关系数据库可以看作是第二代数据库系统。自20世纪70年代提出关系数据模型和关系数据库后,数据库技术得到了蓬勃发展,应用也越来越广泛。但随着应用的不断深入,占主导地位的关系数据库系统已不能满足新的应用领域的需求。正是实际中涌现出的许多问题,促使数据库技术不断向前发展,涌现出许多不同类型的新型数据库系统。,14,下面概要性地作一些介绍。(1)分布式数据库系统 分布式数据库系统(Distributed Database System)是在集中式数据库基础上发展起来的,是数据库技术与计算机网络技术、分布处理技术相结合的产物。分布式数据库系统是地理上分布在计算机网络不同结点,逻辑上属于同一系统的数据库系统,能支持全局应用,同时存取两个或两个以上结点的数据。,15,(2)面向对象数据库系统 面向对象数据库系统(Object-Oriented Database System)是将面向对象的模型、方法和机制,与先进的数据库技术有机地结合而形成的新型数据库系统。它从关系模型中脱离出来,强调在数据库框架中发展类型、数据抽象、继承和持久性。它的基本设计思想是,把面向对象语言向数据库方向扩展,使应用程序能够存取并处理对象,以便对现实世界中复杂应用的实体和联系建模。因此,面向对象数据库系统首先是一个数据库系统,具备数据库系统的基本功能,其次是一个面向对象的系统,针对面向对象的程序设计语言的永久性对象存储管理而设计的,充分支持完整的面向对象概念和机制。,16,(3)多媒体数据库系统 多媒体数据库系统(Multi-media Database System)是数据库技术与多媒体技术相结合的产物。在许多数据库应用领域中,都涉及到大量的多媒体数据,这些与传统的数字、字符等格式化数据有很大的不同,都是一些结构复杂的对象。,17,(4)数据仓库 信息技术的高速发展,数据库应用的规模、范围和深度不断扩大,一般的事务处理已不能满足应用的需要,企业界需要在大量信息数据基础上的决策支持,数据仓库(Data Warehouse)技术的兴起满足了这一需求。数据仓库作为决策支持系统(Decision Support System)的有效解决方案,涉及3方面的技术内容:数据仓库技术、联机分析处 理(On-Line Analysis Processing,OLAP)技术和数据挖掘(Data Mining)技术。,18,1.2 数据库系统,1.2.1 数据库系统的组成1.硬件 2.软件3.数据库4.数据库系统的有关人员1.2.2 数据库系统的特点1数据共享2减少数据冗余3具有较高的数据独立性4增强了数据安全性和完整性保护,19,1.2.1 数据库系统的组成 数据库系统是把有关计算机硬件、软件、数据和人员组合起来为用户提供信息服务的系统。因此,数据库系统是由计算机系统、数据库及其描述机构、数据库管理系统和有关人员组成,是由这几个方面组成的具有高度组织性的总体。1.硬件 数据库系统对计算机硬件的要求除要求CPU的处理速度高、内存容量大以外,还要求有足够的外存空间以存储数据库中的数据。,20,2.软件 数据库系统中的软件包括操作系统、数据库管理系统及数据库应用系统等。数据库管理系统是数据库系统的核心软件之一。它提供数据定义、数据操作、数据库管理、数据库建立和维护以及通信等功能。数据库应用系统是指系统开发人员利用数据库系统资源开发出来的,面向某一类实际应用的应用软件系统。它分为两类:(1)管理信息系统。这是面向机构内部业务和管理的数据库应用系统。(2)开放式信息服务系统。这是面向外部、提供动态信息查询功能,以满足不同信息需求的数据库应用系统。,21,3.数据库 数据库系统中的数据库是按一定法则存储在计算机外存储器中的大批数据。它不仅包括描述事物的数据本身,而且还包括相关事物之间的联系。数据库中的数据往往不是像文件系统那样,只面向某一项特定应用,而是面向多种应用,可以被多个用户、多个应用程序共享。其数据结构独立于使用数据的程序,对于数据的增加、删除、修改和检索由系统软件进行统一的控制。,无论是哪一类信息系统,从实现技术角度而言,都是以数据库技术为基础的计算机应用系统。,22,4.数据库系统的有关人员 数据库系统的有关人员主要有3类:最终用户、数据库应用系统开发人员和数据库管理员(DBA:Database Administrator)。最终用户指通过应用系统的用户界面使用数据库的人员,他们一般对数据库知识了解不多。数据库应用系统开发人员包括系统分析员、系统设计员和程序员。系统分析员负责应用系统的分析,他们和用户、数据库管理员相配合,参与系统分析;系统设计员负责应用系统设计和数据库设计;程序员则根据设计要求进行编码。数据库管理员是数据管理机构的一组人员,他们负责对整个数据库系统进行总体控制和维护,以保证数据库系统的正常运行。,23,1.2.2 数据库系统的特点1数据共享 数据共享是指多个用户可以同时存取数据而不相互影响,数据共享包括以下三个方面:所有用户可以同时存取数据;数据库不仅可以为当前的用户服务,也可以为将来的新用户服务;可以使用多种语言完成与数据库的接口。,24,2减少数据冗余 数据冗余就是数据重复,数据冗余既浪费存储空间,又容易产生数据的不一致。在非数据库系统中,由于每个应用程序都有自己的数据文件,所以数据存在着大量的重复。数据库从全局观念来组织和存储数据,数据已经根据特定的数据模型结构化,在数据库中用户的逻辑数据文件和具体的物理数据文件不必一一对应,从而有效地节省了存储资源,减少了数据冗余,增强了数据的一致性。,25,3具有较高的数据独立性 所谓数据独立是指数据与应用程序之间的彼此独立,它们之间不存在相互依赖的关系。在数据库系统中,数据库管理系统通过映像,实现了应用程序对数据的逻辑结构与物理存储结构之间较高的独立性。数据库的数据独立包括两个方面:(1)物理数据独立:数据的存储格式和组织方法改变时,不影响数据库的逻辑结构,从而不影响应用程序。(2)逻辑数据独立:数据库逻辑结构的变化(如数据定义的修改,数据间联系的变更等)不影响用户的应用程序。,26,4增强了数据安全性和完整性保护 数据库加入了安全保密机制,可以防止对数据的非法存取。由于实行集中控制,有利于控制数据的完整性。数据库系统采取了并发访问控制,保证了数据的正确性。另外,数据库系统还采取了一系列措施,实现了对数据库破坏的恢复。,27,1.3 数据模型,1.3.1 实体及其联系 1实体 2实体间的联系(1)一对一联系(1:1)(2)一对多联系(1:n)(3)多对多联系(m:n)1.3.2 数据模型 1.层次模型 2网状模型 3关系模型,28,1.3.1 实体及其联系1实体 从数据处理的角度看,现实世界中的客观事物称为实体,它可以指人,如一个教师、一个学生等等,也可以指物,如一本书、一张桌子等。它不仅可以指实际的物体,还可以指抽象的事件,如一次借书、一次奖励等等。它还可以指事物与事物之间的的联系,如学生选课、客户订货等。,29,一个实体可有不同的属性,属性描述了实体某一方面的特性。例如,教师实体可以用教师编号、姓名、性别、出生日期、职称、基本工资、研究方向等属性来描述。每个属性可以取不同的值,对于具体的某一教师,其编号为10121、姓名为张三、性别为男、出生日期为1963年9月7日、职称为教授、基本工资为678元、研究方向为网络信息系统,分别为上述教师实体属性的取值。属性值的变化范围称作属性值的域。如性别这个属性的域为(男,女),职称的域为(助教,讲师,副教授,教授)等等,由此可见,属性是个变量,属性值是变量所取的值,而域是变量的变化范围。,30,由上可见,属性值所组成的集合表征一个实体,相应的这些属性的集合表征了一种实体的类型,称为实体型,例如上面的教师编号、姓名、性别、出生日期、职称、基本工资、研究方向等表征“教师”这样一种实体的实体型。同类型的实体的集合称为实体集。在Visual FoxPro中,用“表”来表示同一类实体,即实体集,用“记录”来表示一个具体的实体,用“字段”来表示实体的属性。显然,字段的集合组成一个记录,记录的集合组成一个表。相应于实体型,则代表了表的结构。,31,2实体间的联系 实体之间的对应关系称为联系,它反映了现实世界事物之间的相互关联。例如,图书和出版社之间的关联关系为:一个出版社可出版多种书,同一种书只能在一个出版社出版。实体间的联系是指一个实体集中可能出现的每一个实体与另一实体集中多少个具体实体存在联系。实体之间有各种各样的联系,归纳起来有3种类型:,32,(1)一对一联系(1:1)。如果对于实体集A中的每一个实体,实体集B中有且只有一个实体与之联系,反之亦然,则称实体集A与实体集B具有一对一联系。(2)一对多联系(1:n)。如果对于实体集A中的每一个实体,实体集B中有多个实体与之联系,反之,对于实体集B中的每一个实体,实体集A中至多只有一个实体与之联系,则称实体集A与实体集B有一对多的联系。(3)多对多联系(m:n)。如果对于实体集A中的每一个实体,实体集B中有多个实体与之联系,而对于实体集B中的每一个实体,实体集A中也有多个实体与之联系,则称实体集A与实体集B之间有多对多的联系。,33,1.3.2 数据模型 数据模型是对客观事物及其联系的数据描述,反映实体内部和实体之间的联系。由于采用的数据模型不同,相应的数据库管理系统也就完全不同。在数据库系统中,常用的数据模型有层次模型、网状模型和关系模型3种。,34,1.层次模型 层次模型用树形结构来表示实体及其之间的联系。在这种模型中,数据被组织成由“根”开始的“树”,每个实体由根开始沿着不同的分支放在不同的层次上。树中的每一个结点代表实体型,连线则表示它们之间的关系。根据树形结构的特点,建立数据的层次模型需要满足两个条件:(1)有一个结点没有父结点,这个结点即根结点。(2)其他结点有且仅有一个父结点。,35,层次模型具有层次清晰、构造简单、易于实现等优点。但由于受到如上所述的两个条件的限制,它可以比较方便地表示出一对一和一对多的实体联系,而不能直接表示出多对多的实体,对于多对多的联系,必须先将其分解为几个一对多的联系,才能表示出来。因而,对于复杂的数据关系,实现起来较为麻烦,这就是层次模型的局限性。采用层次模型来设计的数据库称为层次数据库。,36,2网状模型 网状数据模型用以实体型为结点的有向图来表示各实体及其之间的联系。其特点是:(1)可以有一个以上的结点无父结点。(2)至少有一个结点有多于一个的父结点。由于树形结构可以看成是有向图的特例,所以网络模型要比层次模型复杂,但它可以直接用来表示“多对多”联系。然而由于技术上的困难,一些已实现的网状数据库管理系统(如DBTG)中仍然只允许处理“一对多”联系。,37,3关系模型 关系模型与层次模型和网状模型相比有着本质的差别,它是用二维表格来表示实体及其相互之间的联系。在关系模型中,把实体集看成一个二维表,每一个二维表称为一个关系。每个关系均有一个名字,称为关系名。虽然关系模型比层次模型和网状模型发展得晚,但是因为它建立在严格的数学理论基础上,所以是目前比较流行的一种数据模型。自20世纪80年代以来,新推出的数据库管理系统几乎都支持关系模型,Visual FoxPro就是一种关系数据库管理系统。,38,1.4 关系数据库,1.4.1 关系模型 1关系模型的基本概念(1)关系(2)元组(3)属性(4)域(5)关键字(6)候选关键字(7)主关键字(8)外部关键字(9)关系模式2关系的基本特点3关系模型的优点1.4.2 关系数据库,39,1.4.1 关系模型1关系模型的基本概念(1)关系 一个关系就是一张二维表,通常将一个没有重复行、重复列的二维表看成一个关系,每个关系都有一个关系名。在Visual FoxPro中,一个关系对应于一个表文件,其扩展名为.dbf。(2)元组 二维表的每一行在关系中称为元组。在Visual FoxPro中,一个元组对应表中一个记录。,40,(3)属性 二维表的每一列在关系中称为属性,每个属性都有一个属性名,属性值则是各个元组属性的取值。在Visual FoxPro中,一个属性对应表中一个字段,属性名对应字段名,属性值对应于各个记录的字段值。(4)域 属性的取值范围称为域。域作为属性值的集合,其类型与范围具体由属性的性质及其所表示的意义确定。同一属性只能在相同域中取值。,41,(5)关键字 关系中能惟一区分、确定不同元组的属性或属性组合,称为该关系的一个关键字。单个属性组成的关键字称为单关键字,多个属性组合的关键字称为组合关键字。需要强调的是,关键字的属性值不能取“空值”,所谓空值就是“不知道”或“不确定”的值,因而无法惟一地区分、确定元组。(6)候选关键字 关系中能够成为关键字的属性或属性组合可能不是惟一的。凡在关系中能够惟一区分、确定不同元组的属性或属性组合,称为候选关键字。,42,(7)主关键字 在候选关键字中选定一个作为关键字,称为该关系的主关键字。关系中主关键字是惟一的。(8)外部关键字 关系中某个属性或属性组合并非关键字,但却是另一个关系的主关键字,称此属性或属性组合为本关系的外部关键字。关系之间的联系是通过外部关键字实现的。(9)关系模式 对关系的描述称为关系模式,其格式为:关系名(属性名1,属性名2,属性名n)关系既可以用二维表格描述,也可以用数学形式的关系模式来描述。一个关系模式对应一个关系的结构。在Visual FoxPro中,也就是表的结构。,43,2关系的基本特点 在关系模型中,关系具有以下基本特点:(1)关系必须规范化,属性不可再分割。规范化是指关系模型中每个关系模式都必须满足一定的要求,最基本的要求是关系必须是一张二维表,每个属性值必须是不可分割的最小数据单元,即表中不能再包含表。(2)在同一关系中不允许出现相同的属性名。Visual FoxPro不允许同一个表中有相同的字段名。(3)关系中不允许有完全相同的元组,即冗余。,44,(4)在同一关系中元组的次序无关紧要。也就是说,任意交换两行的位置并不影响数据的实际含义。(5)在同一关系中属性的次序无关紧要。任意交换两列的位置也并不影响数据的实际含义,不会改变关系模式。以上是关系的基本性质,也是衡量一个二维表格是否构成关系的基本要素。在这些基本要素中,有一点是关键,即属性不可再分割,也即表中不能套表。,45,3关系模型的优点(1)数据结构单一 关系模型中,不管是实体还是实体之间的联系,都用关系来表示,而关系都对应一张二维数据表,数据结构简单、清晰。(2)关系规范化,并建立在严格的理论基础上,关系中每个属性不可再分割,构成关系的基本规范。同时关系是建立在严格的数学概念基础上,具有坚实的理论基础。(3)概念简单,操作方便 关系模型最大的优点就是简单,用户容易理解和掌握,一个关系就是一张二维表格,用户只需用简单的查询语言就能对数据库进行操作。,46,1.4.2 关系数据库 以关系模型建立的数据库就是关系数据库(RDB:Relational Database)。关系数据库中包含若干个关系,每个关系都由关系模式确定,每个关系模式包含若干个属性和属性对应的域,所以,定义关系数据库就是逐一定义关系模式,对每一关系模式逐一定义属性及其对应的域。一个关系就是一张二维表格,表格由表格结构与数据构成,表格的结构对应关系模式,表格每一列对应关系模式的一个属性,该列的数据类型和取值范围就是该属性的域。因此,定义了表格就定义了对应的关系。,47,在Visual FoxPro中,与关系数据库对应的是数据库文件(.dbc文件),一个数据库文件包含若干个表(.dbf文件),表由表结构与若干个数据记录组成,表结构对应关系模式。每个记录由若干个字段构成,字段对应关系模式的属性,字段的数据类型和取值范围对应属性的域。,48,1.5 Visual FoxPro系统简介,1.5.1 Visual FoxPro系统的发展1.5.2 Visual FoxPro 6.0的特点 1.大大加强了查询与管理功能 2.引入了数据库表的概念 3扩充了对SQL语言的支持 4提供了多种可视化设计工具 5面向对象的程序设计 6提供OLE功能 7支持网络应用,49,1.5.1 Visual FoxPro系统的发展 1983年,美国Ashton-Tate公司(1992年被Borland公司收购)推出了dBASE关系型数据库管理系统,1984年6月又推出了dBASE,随后又推出改进型产品dBASE Plus,功能一代比一代强。dBASE由于使用方便、性能优越,被誉为“大众数据库”,在微机数据库中占有统治地位。但是dBASE仍然存在着不少缺点,如速度慢、人机界面差、不带编译器、命令和函数有限等等。,50,美国Fox Software公司正是看到了dBASE在性能和速度上存在的不足,也预见到了微机数据库系统应用的巨大潜力,推出了与dBASE全兼容的FoxBASE+,其速度和功能都优于dBASE。FoxBASE+1.0版于1987年2月问世,仅隔5个月又推出了2.0版,其最高版本是1988年7月推出的2.1版。,51,1995年6月,Microsoft公司推出了Visual FoxPro 3.0版,接着又很快推出Visual FoxPro 5.0及其中文版,1998年发布了可视化编程语言集成包Visual Studio 6.0。在此介绍的Visual FoxPro 6.0(中文版)就是其中的一员。它是可运行于Windows95/98,Windows NT平台的32位数据库开发系统,能充分发挥32位微处理器的强大功能,是直观易用的编程工具。,52,1.5.2 Visual FoxPro 6.0的特点1.大大加强了查询与管理功能 Visual FoxPro采用了目前先进的Rushmore快速查询技术(索引式快速存取),使Visual FoxPro能快速查询到所需记录,查询响应时间成指数倍减少,极大地提高了查询的效率。Visual FoxPro提供的项目管理器,可供用户对所开发项目中的数据、文档、源代码和类库等资源进行集中管理,提高了开发与维护效率。,53,2.引入了数据库表的概念 从dBASE到FoxPro,每一个数据库文件(使用.dbf作扩展名)都是独立存在的。库文件之间的联系,只能在使用时由用户在编程中用命令来表达。Visual FoxPro改变了这一传统的做法,在定义库文件(在Visual FoxPro中改称为表)时,就将它们区分为属于某一数据库的“数据库表”(Database Table)和不属于任何数据库的“自由表”(Free Table)两大类。对所有的数据库表,在建表时就同时定义它与数据库内其他表之间的关系。这就使Visual FoxPro建立的库表更加符合数据库的实际,也方便了用户随后对这些表的引用。,54,3扩充了对SQL语言的支持 SQL语言是由IBM公司开发的关系数据库语言,其后成为关系数据库的标准语言,其查询语句不仅功能强大,而且使用灵活。在Visual FoxPro 6.0中,SQL语言的命令已扩充到了8条,加强了Visual FoxPro语言的功能。,55,4提供了多种可视化设计工具 Visual FoxPro 6.0提供了向导(Wizard)、设计器(Designer)和生成器(Builder)3类可视化设计工具,能帮助用户以简单的操作,快速完成各种查询和设计任务。,56,5面向对象的程序设计 Visual FoxPro一方面继续使用传统的面向过程的程序设计,另一方面还支持面向对象的程序设计。允许用户对“对象”(Object)和“类”(Class)进行定义,并编写相应的代码。由于Visual FoxPro预先定义和提供了一批基类,用户可以在基类的基础上定义自己的类和子类,从而利用类的继承性。减少编程工作量,加快软件开发过程。,57,6提供OLE功能 OLE是Object Linking and Embedding(对象链接与嵌入)的缩写,是Microsoft公司开发的重要技术。通过这种技术,Visual FoxPro可与其他应用软件共享数据,实现应用集成。例如在不退出Visual FoxPro环境的情况下,用户就可在Visual FoxPro的表单(或窗体)中链接其他软件中的对象,直接对这些对象进行编辑。在通过必要的格式转换后,用户可以在Visual FoxPro与其他软件之间进行数据的传输。Visual FoxPro 6.0还能提供自动的OLE控制,用户借助于这种控制,甚至能通过Visual FoxPro的编程来运行其他软件,让它们完成诸如计算、绘图等功能,实现应用的集成。,58,7支持网络应用 Visual FoxPro既适用于单机环境,也适用于网络环境。其网络功能主要包括:支持客户服务器结构,既可访问本地计算机,也支持对服务器的浏览。对于来自本地、远程或多个数据库表的异种数据,Visual FoxPro可支持用户通过本地或远程视图访问与使用,并在需要时更新表中的数据;在多用户环境中,Visual FoxPro还允许建立事务处理程序来控制对数据的共亭,包括支持用户共享数据,或限制部分用户访问某些数据等。,59,1.6 Visual FoxPro操作基础,1.6.1 Visual FoxPro的安装与启动1.6.2 Visual FoxPro的用户界面1.6.3 Visual FoxPro操作概述1.6.4 Visual FoxPro命令概述,60,1.Visual FoxPro的运行环境(1)处理器:486DX/66MHZ或更高处理器。(2)内 存:16MB以上。(3)硬盘空间:典型安装需要85MB,最大安装需要90MB。(4)显视器:VGA或更高分辩率的显示器。(5)需要一个鼠标、一个光驱。(6)操作系统:Windows 95/Windows 98/Windows 2000/XP/Windows NT 4.0。,1.6.1 Visual FoxPro的安装与启动,61,2.Visual FoxPro的安装从CD-ROM上安装的步骤如下:(1)将Visual FoxPro 6.0系统光盘放入CD-ROM驱动器,在“我的电脑”或“资源管理器”中双击setup.exe文件,或在Windows桌面上单击“开始”按钮,选择“运行”选项,输入F:SETUP(假定CD-ROM驱动器号是F),并且按回车键。运行setup.exe文件后,进入Visual FoxPro安装过程。,62,(2)按照安装向导的提示,单击“下一步”按钮,进入用户许可协议界面。选择“接受协议”后,单击“下一步”按钮。,63,(3)在产品号和用户ID界面,输入产品的ID号和用户信息。只有输入正确的产品ID号,安装才能继续。(4)为Visual Studio 6.0应用程序所公用的文件选择安装位置。默认情况下,Visual FoxPro会自动将公用文件安装在C:Program FilesMicrosoft Visual StudioCommon目录下,如果用户还安装了其他Visual Studio 6.0的产品,最好不要更改此目录。(改盘符即可),64,(5)单击“下一步”按钮后,进入Visual FoxPro 6.0的安装程序,选择安装类型。,典型安装(85MB),选择“典型安装(T)”,该选项将安装最典型的组件,并将帮助文件留在CD-ROM上。若需要安装其他的Visual FoxPro文件,包括ActiveX控件或企业版文件,选择“自定义安装(U)”,该选项允许自定义要安装的组件。系统默认安装所有文件。,65,3.Visual FoxPro的启动与退出AVisual FoxPro 6.0的启动(1)开始|程序|Microsoft visual foxpro 6.0(2)在桌面创建快捷图标,66,此为Visual FoxPro主窗口。它的出现,表示已成功地进入Visual FoxPro操作环境。,67,BVisual FoxPro 6.0的退出(1)在Visual FoxPro“文件”菜单项下,选择“退出”菜单项。(2)在Visual FoxPro命令窗口输入QUIT命令并回车。(3)单击Visual FoxPro主窗口右上角的关闭按钮。(4)单击Visual FoxPro主窗口左上角的控制菜单图标,从弹出的菜单中选择“关闭”。或者双击控制菜单图标。(5)同时按Alt和F4键。,68,一、Visual FoxPro系统菜单1Visual FoxPro菜单的约定(1)带“省略号”的菜单选项 如果在菜单选项右方紧跟一个省略号(),表示选择该项后将弹出一个对话框,等待用户继续选择。(2)带向右箭头的菜单选项有些菜单选项后面带有一个向右箭头,表示选择该项会打开一个子菜单。(3)有“对号”的菜单选项如果菜单选项被选择后在其左方出现一个“对号”(),表示该项在当前有效。,1.6.2 Visual FoxPro的用户界面,69,(4)灰色菜单选项当菜单选项以灰色显示时,表示该项在当前条件下不能使用,例如,如果现在未打开任何文件,则文件菜单项下的“保存”、“另存为”将呈现灰色。因为此时无文件需要保存。,70,(5)热键和快捷键热键和快捷键均用于键盘操作。前者指菜单项中带下划线的字母,例如“文件”菜单项中的F,“格式”菜单项中的O等。后者常出现在菜单项名称的右方,一般采用组合键的形式,例如,“文件”菜单项下的“新建”为“Ctrl+N”,“打开”为“Ctrl+O”等。如果用户记住了这些键,可直接用它们来选择菜单项,比逐级选择更省时间。ALT+F-打开文件菜单,71,(1)“文件”菜单“文件”菜单用于新建、打开、保存和打印以及退出Visual FoxPro等操作。(2)“编辑”菜单“编辑”菜单提供了许多编辑功能。在编辑窗口编辑Visual FoxPro程序文件时,选取某个菜单项就可完成某项操作,如剪切、复制、粘贴、查找、替换等。,2Visual FoxPro菜单项的功能,Vfp菜单为动态菜单,即随着执行某项功能,系统主菜单和其下的子菜单会动态地修改或增加一些菜单项,72,“编辑”菜单还允许插入在其他非Visual FoxPro应用程序中创建的对象,如文档、图形、电子表格等。使用Microsoft的对象链接与嵌入(OLE)技术,可以在通用型字段中嵌入一个对象或者将该对象与创建它的应用程序链接起来。只有处于通用型字段的编辑窗口时,“编辑”菜单中的插入对象、对象、链接选项才是可选的。,73,(3)“显示”菜单“显示”菜单主要是显示Visual FoxPro的各种控件和设计器,如表单控件、表单设计器、查询设计器、视图设计器、报表控件、报表设计器、数据库设计器等。(4)“格式”菜单“格式”菜单提供一些排版方面的功能,允许用户在显示正文时选择字体和行间距,检查在正文编辑窗口中的拼写错误,确定缩进和不缩进段落等。(5)“工具”菜单“工具”菜单提供了表、查询、表单、报表、标签等项目的向导模块。,74,(6)“程序”菜单“程序”菜单用于程序运行控制、程序调试等。(7)“窗口”菜单“窗口”菜单用于Visual FoxPro窗口的控制。单击窗口菜单中的“命令窗口”,可打开“命令窗口”进入命令编辑方式。(8)“帮助”菜单在菜单栏的最右边是帮助菜单,该菜单为用户提供帮助信息。,75,二、Visual FoxPro命令窗口1命令窗口的隐藏与激活Visual FoxPro启动后,命令窗口被自动设置为活动窗口,在窗口左上角出现插入光标,等待用户键入命令。隐藏命令窗口,使之在屏幕上不可见,可以选择“窗口”菜单项中的“隐藏”选项。命令窗口被隐藏后,按快捷键Ctrl+F2,或在“窗口”菜单项中选择“命令窗口”选项,则命令窗口被激活,再现在Visual FoxPro主窗口。,76,2命令窗口的使用(1)Visual FoxPro的命令工作方式在命令窗口中输入一条命令,Visual FoxPro即刻执行该命令,并在主窗口显示命令的执行结果,然后返回命令窗口,等待用户的下一条命令。例如,在命令窗口输入以下两条命令:?8*11?(8+9)/2将立即在主窗口显示执行结果:88和8.5,77,这里用到了Visual FoxPro中最简单的一条命令表达式输出命令。关于表达式将在下一章介绍,这里先介绍该命令。命令格式:?|?该命令的功能是依次计算并显示各表达式的值。?与?的区别在于:?在显示表达式内容之前,先发送出一个回车换行符;而?则不发出回车换行符,从光标当前位置开始输出。,78,(2)命令窗口的自动响应菜单操作功能。当在Visual FoxPro菜单中选择某个菜单选项时,Visual FoxPro会把与该操作等价的命令自动显示在命令窗口。对于初学者来说,这也是学习Visual FoxPro命令的一种好方法。,79,(3)命令窗口的命令记忆功能Visual FoxPro在内存设置一个缓冲区,用于存储已执行过的命令。通过使用命令窗口右侧的滚动条,或用键盘上、下光标移动键能把光标移至曾执行过的某个命令上。这不仅可用于命令的查看、重复执行,而且对于纠正错误、调试程序是非常有用的。,80,三、Visual FoxPro工具栏工具栏指的是将大多数常用的功能或工具操作放入某一个工具栏中,以方便用户的操作和查询。在Visual FoxPro 6.0中有许多设计器,每种设计器都有一个或多个工具栏。在操作时,可以根据需要在屏幕上放置多个工具栏,通过把工具栏停放在屏幕的上部、底部或两边,可以定制工作环境。Visual FoxPro 6.0能够记忆工具栏的位置,再次进入Visual FoxPro时,工具栏将位于关闭时所在的位置上。,81,1显示或隐藏工具栏,若需要显示或隐藏某一个工具栏,可以单击“显示”菜单/“工具栏”选项,此时出现工具栏对话框,选择或清除相应的工具栏,然后单击“确定”按钮,便可显示或隐藏选定的工具栏。,82,2.常用工具栏3.其他工具栏VFP提供了10种工具栏:打开工具栏的方法:在主菜单中选择|显示|工具栏,83,在工具栏对话框的下面是显示选项,其中有3个复选框。选中“彩色按钮”选项表示系统中的工具栏按钮将变为彩色按钮,否则所有的工具栏按钮都将为黑白的,系统默认为彩色按钮。选中“大按钮”选项,则系统中的工具栏按钮将放大一倍,不选中时恢复原样,即为小按钮,系统默认为小按钮。选中“工具提示”选项表示每个工具栏中的按钮都有文本提示功能,即把鼠标指针停留在某个按钮图标时,系统将自动显示出该按钮图标的名称,否则,不显示名称,系统默认为显示工具提示。,84,四、Visual FoxPro状态栏1菜单选项的功能当选择了某一菜单选项时,就会在状态栏显示该选项的功能,使用户能及时了解所选命令的作用。例如在“文件”菜单中选择“打开”命令时,状态栏将显示“打开已有文件”,选择“退出”命令时将显示“退出Visual FoxPro”等。2系统对用户的反馈信息Visual FoxPro命令执行后,系统在状态栏向用户反馈有关执行情况。,85,3当前操作状态状态栏右边有3个方格。左格