1、2.2 VFP文件类型,文件类型(参见P35)创建文件极少使用菜单而是使用“项目管理器”中的“新建” 设计器(Designer)和向导(Wizard) 各种文件可用的设计器和向导,1. 数据库(Database)数据库文件(.dbc)关联的数据库备注文件(.dct)关联的索引文件(.dcx)数据库是一个包容器,用来组织和联系表,它提供了存储数据的一种体系结构。数据库中若有数据库表,则数据库不但可以组织和管理表,而且可以创建表、记录和字段级的规则、缺省值、触发器、存储过程和永久的表关联。若创建一个数据库,系统自动生成文件名相同、但扩展名不同的三个文件。,2. 表(Table) 表文件(.dbf)
2、它是存放表结构和数据的文件,是数据库操作最基本、最重要的主文件。它以记录和字段的二维表格形式存储数据。Visual FoxPro的表分为两种:数据库表和自由表。 备注文件(.fpt)它用来存放表文件中备注型字段的内容,该文件的主名与表文件名相同,扩展名不同。 索引文件(.idx或.cdx)它是对表文件的记录按索引关键字段值排序后建立的辅助文件。,学号 姓名 性别 专业代号 简历 990101 章三 男 102001 Memo990102 李辉 男 102001 Memo990103 黄化 女 102002 Memo,字段,记录,关系,学生,关系名,例如,数据库表是存放在数据库中的表,是数据库的
3、基础。数据库中的每个数据库表之间可以建立联系。,自由表是独立的,只能对其本身进行各种操作。在创建表时,若没有任何数据库打开,则创建的是自由表。,3. 查询和视图 查询(Query)从指定的表或视图中快速地筛选出需要的记录,为报表或表单组织信息,或用查询结果创建新的表和图形。查询文件的扩展名为 .qpr。 视图(View)视图是一个定制的虚拟表或逻辑表,它是有一个已经存在或多个相关的数据表根据需要组织起来的查看数据表的一个窗口,通过它不仅可以查看表中感兴趣的内容,而且可以更新表的数据。视图分为本地视图和远程视图。,4.报表和标签 报表(Report)报表是Visual FoxPro最重要的打印输
4、出文件,也是一个应用系统设计的重要部分。实际管理工作中需要打印各种报表。它是用户自行设计的存放数据库报表输出格式的文件,如有报表标题、各项小计、总和以及打印格式等。报表文件的扩展名为 .frx。 标签(Label)标签是类似“名片”形状的打印输出方式。即表中的每一条记录分别作为一个输出单元。每张纸可以打印若干个标签。标签文件的扩展名为 .lbx。,5. 表单(Form) 表单是应用系统最主要的操作界面,是最体现面向对象程序设计的思想和方法的工具。 表单又是实现各种操作功能的“窗口”,如数据的输入、维护、查询、报表打印等。 Visual FoxPro面向对象的程序设计主要是各种表单的设计。 表单
5、文件的扩展名是.scx。,6.菜单(Menu) 菜单为用户提供了一个结构化访问的途径,从而方便用户使用应用程序中命令和工具。 菜单系统由菜单栏、菜单标题、菜单以及菜单项组成。 它常处于程序的主窗口中,是构成应用程序主框架的一个重要组成部分。 菜单文件的扩展名是.mnx,菜单备注文件的扩展名是.mnt。,7. 程序(Program) 程序文件(.prg)它是用户将数据库命令和语句编写成特定的应用程序构成的文件,以程序形式自动执行一连串的命令和语句,进行数据库操作。应用程序文件(.app)它是用户使用项目管理器而建立的一套完整的应用程序系统,它作为一个独立的文件,供用户执行。可执行文件(.exe)
6、它也是用户使用项目管理器而建立的一套完整的应用程序系统,它可以独立VFP环境而运行。,2.3 VFP项目管理器及其操作,控制中心、管理中心 项目管理器(Project Manager)是VFP中处理数据和对象的主要组织工具 项目是文件、数据、文档和VFP对象的集合 项目文件. PJX 备注文件. PJT,创建项目文件法1:使用命令CREATE PROJECTCREATE PROJECT 法2:使用“文件”菜单中“新建” 法3:工具栏上的“新建”按钮,图2-3 “项目管理器”窗口,2.3.1 页面,1. 用“选项卡”分类显示项目中各类型数据项 (1)全部 (2)数据:一个项目中的所有数据(数据库
7、、自由表、查询、视图) (3)文档:处理数据时所用的全部文档(表单、报表和标签) (4)类:表单和程序中所用的类库和类 (5)代码:程序、API库和应用程序 (6)其他:菜单、文本文件和其他文件(如位图、图标等),2. 用“项列表”查看项目中的内容 相当于大纲视图或资源管理器 带斜线的圆圈:连编时将被排除 +号:展开 -号:折叠 所有的包含文件在运行时都是只读的 在程序、表单、查询、菜单组中,主程序文件用粗体表示,2.3.2 定制项目管理器 拖动到屏幕顶部 双击标题栏:泊留项目管理器 展开折叠按钮 撕下选项卡 图钉按钮,2.3.3 项目管理器的操作 1. 命令按钮 (1)新建:创建一个新文件或
8、对象 (2)添加:把现有文件添加到项目中 (3)修改:相应设计器 (4)浏览:在浏览窗口中打开选定的表或视图,当且 仅当选定一张表或视图时可用 (5)关闭:关闭数据库,当且仅当选定一个数据库时可用 (6)打开:打开数据库,当且仅当选定一个数据库时可用 (7)移去:从项目中移去选定的文件或对象 (8)连编:连编一个项目或应用程序(可执行程序) (9)预览:在打印预览方式下显示选定的报表或标签 (10)运行:执行选定的查询、表单或程序,2.快捷菜单命令 包含/删除 设置主文件 重命名 编辑说明 项目信息,3. 项目间共享文件 引用-非复制 一个文件可同时属于不同的项目 步骤: 打开两项目 在包含该
9、文件的项目管理器中选择该文件,然后拖动该文件到另一个项目容器中即可,退出VFP,法1:“关闭“按钮 法2:文件/退出 法3:QUIT,2.4 VFP 语言基础,2.4.1 数据类型和字段类型 2.4.2 常量与变量 2.4.3 函数 2.4.4 运算符与表达式 2.4.5 空值处理,程序设计基础,2.4.1 数据类型和字段类型,字符型(Character) 货币型(Currency) 数值型(Numeric) 日期型(Date) 逻辑型(Logical) 备注型(Memory) 通用型(General),浮动型(Float) 日期时间型 (DateTime) 双精度型 (Double) 整数型
10、(Integer) 二进制字符型(Character binary) 二进制备注型(Memory binary),必须用西文方式的单或双引号括起。LIST FOR 雇员.职务=总经理 学号、工号、电话号码、邮政编码(看上去象数值型),2.4.1 数据类型和字段类型,1. 字符型(Character) 包括所有英文字符、汉字、数字字符和其他专用符号,其最大长度为254个字符。一个字符占一个字节的存储空间,一个汉字占两个字节。,2.4.1 数据类型和字段类型,2. 货币型(Currency) 当涉及到货币时,可使用货币型代替数值型。 VFP中货币型最多只允许有4位小数,即小数位数超过4位时,VFP
11、会将该数据四舍五入。货币型数据前自动有一个“$”符号。宽度固定为8 。 cPrice=$100.356,STORE 3.14159 TO pi temp=100.12,2.4.1 数据类型和字段类型,3. 数值型(Numeric) 包括整型数、实型数和浮点型数,只能由数字09、小数点和正负号组成。其数据最大长度可达20位,精度16位。定义数值型数据时,要同时说明它的宽度和小数位数。宽度是指数据的总宽度,即包括符号和小数点。例如: 数值 -128.12宽度为7位,小数位数为2位,4. 日期型(Date) 用于表示一个日期,宽度固定为8。其格式有:美式 mm/dd/yy(月/日/年)欧式 dd/m
12、m/yy(日/月/年)中式 yy/mm/dd(年/月/日) 可由用户按使用习惯,用以下命令设置:SET DATE TO YMD/MDY/DMY 日期间的分隔符可以是“/”或“-”,可用以下命令设置:SET MARK TO 日期数据中的年份位数,可用以下命令设置:SET CENTURY ON /OFF 例如:10/28/08或 08-10-28 都是表示2008年10月28日的正确日期格式,birthday=1968/05/20 Dblankdate= 日期时间型(DateTime) tdatetime=4/17/ 2000 8:30pm Tdateonly=4/17/ 2000 Ttimeon
13、ly=8:30pm Tblankdate= :,2.4.1 数据类型和字段类型,STORE .T. TO found Flag=.F.,2.4.1 数据类型和字段类型,5. 逻辑型(Logical) 是用于进行各种逻辑判断的数据。用.T.或.Y.表示逻辑真值,而.F.或.N.表示逻辑假值。其宽度固定为1。,6. 备注型(Memory) 也称为记忆型,它也是数据库中特有的数据类型,用于存放记录中一些较大的文本。 其宽度固定为4 ,用于存放一指针,指向字段的真正内容,该字段的真正内容存放在与表文件同名的一个表备注文件中(.FPT)中。 当复制和修改含有备注型字段的表文件名时,必须同时修改相应的备注
14、文件名。,7. 通用型(General) 是数据库中特有的数据类型,用于保存OLE对象,能够存入其他应用程序中的图象、声音、文件、电子表格等。 其宽度固定为4 , 用于存放一指针,指向字段的真正内容。,2.4.2 常量与变量,VFP允许使用常量、变量、数组、记录和对象来存储数据,它们也被称为存储数据的容器 1. 常量(Constants) 2. 变量(Variables) 3. 数组(Arrays) 4. 字段(Fields) 5. 对象(Objects),VFP中的命名规则,数据容器和自定义函数/过程都需要一个名称 当建立名时,必须符合如下规则: 名称中只能包含字母、汉字、下划线“_”和数字
15、符号; 名称的开头只能是字母、汉字或下划线,不能是数字; 自由表的字段名、表的索引标识名至多只能10个字符,其余的名称的长度可以在1128个字符之间; 避免使用VFP系统的保留字。,变量是在程序运行的不同时刻,其值会发生变化的量。 在VFP中,变量具有变量名、变量值、变量类型、长度、变量作用域等属性。,(1)变量的分类,(3)变量的引用,(2)变量的赋值,(4)变量的操作,2. 变量,(1) 变量的分类,字段变量,内存变量,一般内存变量,系统内存变量,数组变量,字段变量是指数据表中已定义的任意一个字段。 由于在一个数据表中,字段的值是随着记录行的变化而变化的,所以称它为变量。 使用字段变量首先
16、要建立数据表,在建立表的过程中创建字段变量。 字段变量是一种多值变量。 它的数据类型有字符型、数值型、浮点型、日期型、逻辑型、备注型和通用型等13种。,字段变量,是独立于数据库以外,存于内存之中的一种临时变量。当退出VFP系统时,一般内存变量自动消失。 它的类型由它所保存的数据的类型决定,有字符型、数值型、浮点型、日期型、逻辑型等7种。 一般内存变量名最多可有128个字符,它由字母、汉字、数字和下划线组成的字符串,但必须以字母、汉字或下划线开头,中间不能有空格。变量名不能使用系统的保留字。,一般内存变量,是VFP建立并自动维护的内部内存变量。 这些变量的名称系统已经定义好,并且以下划线“_”开
17、头。因此在定义其他内存变量名时,最好不要以下划线开头,以免与系统变量重名。 系统变量的类型有数值型、字符型、逻辑型、日期型和对象型。,系统内存变量,是一种特殊的内存变量。是指一组有序的数据的集合,数组中的各元素称为数组元素。 数组在使用前必须事先加以定义,以确定数组名和数组元素的个数。 例如:A(2,5),C(10),数组变量,(2)变量的创建,格式1: STORE TO 格式2: = 功能: 将数据存入内存变量中,建立内存变量。 说明: STORE 可以同时给多个内存变量赋相同值,而等号形式的赋值操作一次只能给一个内存变量赋值。 例如:STORE 50 TO a,b,cSTORE 99-05
18、-04 TO de=Hellof=.T.,问题:STORE 7 TO M,NM,N=7STORE 6 , 7 TO M,N,LOCAL 指定局部变量只能在创建它们的程序中使用和修改,不能被更高层次或更低的程序访问。 PRIVATE 指定私有变量将程序中定义的变量和数组在当前程序中隐藏起来,这样,用户可以在当前程序中重新使用和这些变量同名的变量,而不影响变量的原始值。 PUBLIC 指定全局(公共变量)任何运行的程序都能使用和修改在命令窗口中创建的任何变量都是全局变量,(3) 变量的作用域,(4) 变量的引用,在程序中变量可以直接用变量名引用其值。 如果内存变量与当前打开的数据表文件中的字段同名
19、,在显示时字段变量优先于内存变量,此时若要显示内存变量的内容,必须在内存变量名前加写“M”或“M.”以示区别,而字段名可直接引用。 例如:“M-姓名”,1) 显示一般内存变量 格式1:DISPLAY MEMORY 格式2:LIST MEMORY 2) 清除一般内存变量 格式1:RELEASE 格式2:CLEAR MEMORY 3) 保存一般内存变量 格式:SAVE TO 4) 恢复一般内存变量 格式:RESTORE FROM ,(5)变量的操作,例如:gn=50gc=HelloSAVE TO tempCLEA MEMODISP MEMO LIKE g*gd=date( )DISP MEMO LIKE g*RESTORE FROM temp ADDIDISP MEMO LIKE g*,