FoxPro常用函数及应用_第1页
FoxPro常用函数及应用_第2页
FoxPro常用函数及应用_第3页
FoxPro常用函数及应用_第4页
FoxPro常用函数及应用_第5页
已阅读5页,还剩19页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、2.3 FoxPro常用函数及应用 FoxPro提供了大量的函数(也称为内部函数),每个函数可以完成一个特定的加工过程,并返回一个值。 FoxPro内部函数的调用格式如下: 函数名(参数1,参数2,参数n) 每个函数都规定了不同的参数个数、顺序和类型,调用时必须在个数、次序、类型上和规定的一致。每个参数都可以用常量、变量或表达式(包括函数)来代替,如果函数无参数,函数名后的圆括号也不能够省略(宏代换函数&是唯一的例外)。 使用函数,必须注意三个问题:函数的调用格式;参数的个数及其数据类型;函数返回值的类型。2.4.2 命令的书写规则 使用FoxPro命令时应遵循如下规则: 每条命令必须

2、以命令动词开头,且必须符合命令的语法格式。 限制性短语在命令行中出现的先后次序无关紧要。 命令动词与限制性短语之间、子句与子句之间以及各个选项之间必须至少用一个空格隔开。 命令中的字母不分大小写 一条命令的最大长度可以为2048个字符,如果命令较长可分多行书写,但必须在每行的结尾使用分行符“;”(最后一行不用)。 一行内只允许写一条命令,每条命令用回车符作为结束标志。建立数据库建立数据库 定义数据库的结构,即确定数据库的字段名(Name)、字段类型(Type)、字段宽度(Width)和小数位数(Dec)。 字段名是某个字段的名字,在一个数据库文件中必须唯一。字段名必须以字母开头,后跟字母、数字

3、或下划线,最多可达10个字符。字段名中不允许有空格,且不分大小写字母,FoxPro一律看作大写。在中文版FoxPro中,允许使用汉字作为字段名(一个汉字占两个字符的宽度)。 字段类型是指该字段所存放的数据的类型。Foxpro 2.5/2.6所支持的数据类型包括:字符型(C)、数值型(N)、浮点型(F)、日期型(D)、逻辑型(L)、备注型(M)和通用型(G)。 字段宽度说明该字段允许存放对象的最大字符数。字符型字段的宽度为1254。数值型和浮点型字段的宽度为120。系统自动设置逻辑型、日期型字段的宽度分别为1和8。 备注型字段的长度仅受磁盘可用空间的限制. 小数位数仅用于数值型和浮点型字段,允许

4、取值015,有效位数为16位,统计宽度时,小数点本身也占一个字符。打开数据库USEUSE | ? IN AGAIN INDEX | ? ORDER | | TAG OF ASCENDING | DESCENDINGALIAS EXCLUSIVE SHARED NOUPDATE2.4 FoxPro命令的格式及书写规则命令的格式及书写规则 每条Foxpro命令都有其特定的语法结构,用以说明为实现该命令的功能所必须包含和可以任选的成分。一条典型的操作命令由命令动词、操作对象和限制性短语三部分组成。 命令动词命令动词 所有命令都以命令动词开头,它规定了命令要完成的功能。命令动词通常为一个英文动词,该动

5、词的英文含义表示要执行的操作。例如,HELP(帮助命令)、DO (执行命令)。 REST 操作对象为从当前记录开始直到最后的所有记录 限制性短语限制性短语 限制性短语规定对操作的种种限制,包括条件限制(FOR、WHILE )、 数据来源限制(FROM、WITH)和输出结果去向限制(TO)等。 例如: DISPLAY NEXT 20 FIELDS 姓名,职称,工作单位 FOR 教授$职称 TO PRINT 操作对象操作对象 指出命令所作用的对象,可以是字段名、操作范围、文件名等。其中,操作范围规定了命令所作用的记录的范围。有如下四种情况: ALL 操作对象为全部记录 NEXT 操作对象为从当前记

6、录开始的连续n条记录 RECORD 操作对象为第n条记录 显示数据库记录LIST/DISPLAY FIELDS FOR WHILE OFF NOCONSOLE NOOPTIMIZE TO PRINTER PROMPT | TO FILE 省略和,对LIST,默认范围为ALL;对DISPLAY,默认为当前记录。 当SET DELETE设置为ON时,逻辑删除的记录不会显示出来。 带OFF选项不显示记录号。WHILE显示连续符合条件的记录,直到为假,即使其后仍有使为真的记录也不再显示。FOR显示指定范围内符合本条件的所有记录。 使用TO PRINTERPROMPT/TO FILE选项可将数据库记录送

7、到打印机或存入指定的磁盘文件(缺省扩展名为.TXT)中。加入PROMPT可打开一个对话框,以设定打印机的状态及份数等,该参数只适用于FoxPro for Windows。使用NOCONSOLE选项可使数据在打印或存人磁盘文件的同时不显示在屏幕上,加入NOOPTIMIZE参数将不用Rushmore优化技术。记录的定位与顺序查找1. 绝对定位GOGOTOGO/GOTORECORD IN |IN 或者 GO/GOTO TOP | BOTTOM IN |IN 的值必须大于0且小于或等于数据库中的记录个数。GO TOP将记录指针指向第一条记录;GO BOTTOM将记录指针指向最后一条记录。IN /IN表

8、示在不退出本工作区的情况下移动别的工作区中的记录指针。若数据库建了索引,则GO TOP指向关键值最小的记录,GO BOTTOM指向关键值最大的记录。2. 相对定位SKIP【格式】 SKIP IN | 【功能】 在当前或指定的数据库中向前或向后移动记录指针。【说明】 确定记录指针移动的记录数,为正数则向后移;为负数则向前移,若省略,则向后移一条记录。 可在当前工作区中移动其它工作区中数据库的记录指针。 数据库的第一条记录不是文件头,只有执行SKIP -1后才到达文件头,即BOF()值为.T.,RECNO()为1;同样,最后一条记录不是文件尾,只有执行SKIP后,才到文件尾,即EOF()值为.T.

9、。3条件定位LOCATE【格式】LOCATE FOR WHILE NOOPTIMIZE【功能】条件查询数据库中第一个满足给定条件的记录。【说明】 该命令只能找到满足条件的第一条记录,此时FOUND()函数返回.T.,EOF()返回.F.。 可用CONTINUE连续查找是否还有满足条件的记录,若无,则FOUND()函数返回.F.,EOF()返回.T.。 命令中省略范围时默认为ALL。 其余选项功能同前。 3.2.4 插入记录【格式】INSERT BEFORE BLANK【功能】在当前记录的后面插入一条新记录且立即显示此新记录用于编辑。【说明】 加上BEFORE则所插入的记录会放于当前记录指针所指

10、的记录前面,且用于编辑,若SET CARRY设置为ON,则上一条记录的内容会自动带到新的记录中。 (2)BLANK用来向当前数据库的当前记录之后(前)插入一条空记录。 3.2.5 删除记录 对于无用的记录,可以删除它。在FoxPro中,删除分为逻辑删除和物理删除。逻辑删除的记录还可以恢复,而物理删除的记录则不能恢复。1逻辑删除记录DELETE【格式】DELETEFORWHILE NOOPTIMIZE【功能】在当前的数据库中给要删除的记录做删除标记。【说明】 给要删除的记录做删除标记,但并未从数据库中真正删除记录。 省略和,则默认为当前记录。 其它选项同前。2. 恢复记录RECALL【格式】RE

11、CALL FOR WHILE NOOPTIMIZE【功能】将数据库中标有删除标记的记录恢复(还原)【说明】恢复当前选择的数据库中范围为符合条件的做了删除标记的记录,意即删除标记被取消,省略和时,默认为当前记录。3物理删除记录PACK/ZAP【格式一】PACK MEMO DBF【功能】把当前打开的数据库文件中做过删除标记的记录真正删除掉。【说明】 一旦执行PACK命令,被删除的记录不能再使用RECALL命令恢复。 (2)使用MEMO选项只清除备注文件中的多余空白,以减小备注文件的大小,但不删除带“标记”的记录;使用DBF选项只删除带“标记”的记录,但不清除备注文件中的多余空白;不带MEMO和DBF选项,则可以同时删除带“标记”的记录和备注文件中的空白。【格式二】ZAP【功能】删除当前打开的数据库中所有的记录。【说明】ZAP命令将当前数据库中的所有记录真正删除,仅留下数据库结构。ZAP等价于DELETE ALL和PACK命令。3.2.6 自动替换字段【格式】 REPLACE WITH ADDITIVE, WITH ADDITIVE . FOR WHILE NOOPTIMIZE【功能】用表达式(、)的值替换数据库中原来字段(、)中的数据。【说明】 对于数值型字段,若,的值比字段实际宽度长,那么REPLACE命令将按下面规则强制执行: 首先,

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论