数据库系统及应用第7章-程序设计基础.ppt
第第7 7章程序设计基础章程序设计基础数据数据库系系统及及应用用第第7 7章程序设计基础章程序设计基础教学目标教学目标教学目标教学目标通过本章学习,学生应理解Visual FoxPro结构化程序设计方法;理解程序设计的基本结构;掌握建立和运行程序文件的方法;掌握顺序、分支、循环语句的语法格式及应用;掌握自定义过程及函数的基本概念;熟悉调用过程及函数的方法;能用结构化程序设计方法编写应用程序实现一些基本的功能要求。数据数据库系系统及及应用用第第7 7章程序设计基础章程序设计基础教学要求教学要求教学要求教学要求知识要点知识要点能力要求能力要求关联知识关联知识程序文件的建立与运行了解Visual FoxPro程序文件的书写规则掌握建立、编辑、保存和执行程序文件的方法Visual FoxPro开发环境程序设计基本结构理解Visual FoxPro程序的三大基本结构了解程序设计流程图结构化程序设计的基本概念及特点顺序结构程序设计熟悉程序设计辅助命令掌握基本的输入输出命令掌握赋值语句数据与数据运算常量与变量函数与表达式分支结构程序设计掌握简单分支结构语句掌握多分支结构语句分支结构的概念循环结构程序设计掌握单重循环程序设计掌握多重循环程序设计循环结构的概念过程与函数掌握过程、函数的建立和调用方法掌握参数传递的基本概念掌握过程、函数的应用自定义函数及过程数据数据库系系统及及应用用7.17.1程序与程序文件程序与程序文件(1)命令方式格式:MODIFY COMMAND 功能:打开文本编辑器窗口,输入程序代码。说明:运行该命令时,系统先在磁盘的当前目录下搜索是否已有该文件,若文件尚未建立,则由该命令自动创建一个新文件,若该文件已经存在,则打开该文件供用户编辑修改。如果命令中没有给出,系统会自动创建一个新程序文件。若文件为默认的程序文件,则命令中的扩展名.prg可以省略。7.1.1打开程序文本编辑器数据数据库系系统及及应用用7.17.1程序与程序文件程序与程序文件(2)菜单方式执行【文件】|【新建】命令,或者单击工具栏上的【新建】按钮,打开新建对话框。在新建对话框中选择【程序】项,再单击【新建文件】按钮,即可打开文本编辑窗口。(3)在“项目管理器”中,选定【代码】选项卡中的【程序】项。单击【新建】按钮,也可以打开程序编辑窗口。7.1.1打开程序文本编辑器数据数据库系系统及及应用用7.17.1程序与程序文件程序与程序文件7.1.2输入程序代码数据数据库系系统及及应用用7.17.1程序与程序文件程序与程序文件7.1.3保存程序文件数据数据库系系统及及应用用7.17.1程序与程序文件程序与程序文件7.1.4运行程序文件(1)命令方式格式:DO 功能:调用程序文件并执行。说明:程序文件名前可以使用路径,以指定文件的存放位置,如果没有指定的路径,则指当前目录,如果文件名的扩展名是“.prg”,可以省略文件扩展名。(2)菜单方式执行【程序】|【运行】命令,或按Ctrl+D组合键,打开“运行”对话框。然后在文件列表框中选择要运行的程序,单击【运行】按钮直接运行该程序。(3)若程序文件正处于打开状态,即在程序编辑窗口中,则使用Ctrl+E组合键,或单击常用工具栏中的【运行】按钮运行当前程序。数据数据库系系统及及应用用7.17.1程序与程序文件程序与程序文件7.1.4运行程序文件数据数据库系系统及及应用用7.27.2程序设计常用命令程序设计常用命令7.2.1环境设置命令命令命令命令功能功能CLEAR清屏幕CLEAR ALL关闭所有文件,释放所有内存变量,置1号工作区为当前工作区SET TALK ON|OFF设置所有的命令执行的结果是否显示,默认值为ONSET ECHO ON|OFF设置是否打开跟踪窗口,默认值为 OFFSET DEFAULT TO设置文件访问时默认的驱动器SET PATH TO设置文件访问时默认的路径SET STATUS ON|OFF设置是否显示状态行,默认值为ONSET SAFETY ON|OFF设置当文件重写或被覆盖操作时,是否有安全提示,默认值为ONSET HEADING ON|OFF设置执行LIST或DISPLAY命令时,是否显示字段名,默认值为ONSET ESCAPE ON|OFF设置按ESC键时,是否终止程序执行,默认值为ONSET CONSOLE ON|OFF设置键盘输入的信息,是否发送到屏幕上,默认值为ONSET PRINT ON|OFF设置输出结果是否送到打印机,默认值为 OFFSET DELETED ON|OFF设置逻辑删除记录是否不参与操作,默认值为 OFF数据数据库系系统及及应用用7.27.2程序设计常用命令程序设计常用命令7.2.2基本输入输出命令INPUT命令命令1格式:INPUT TO 功能:暂停程序运行,在屏幕上显示提示信息,等待用户从键盘上输入一个表达式。用户输入完毕后,计算机将表达式的值赋给指定的内存变量,继续执行程序。说明:(1)是可选的,可以是一个字符串或字符串表达式。(2)输入的数据可以是N、C、D、L型表达式,但必须是可以计算出确定值的表达式。系统先计算表达式的值,然后赋给指定的内存变量。(3)本命令允许输入数据常量。(4)按【Enter】键结束输入。数据数据库系系统及及应用用7.27.2程序设计常用命令程序设计常用命令7.2.2基本输入输出命令ACCEPT命令命令2格式:ACCEPT TO 功能:暂停程序运行,在屏幕上显示提示信息,等待用户从键盘上输入一串字符。用户输入完毕后,计算机将表达式的值赋给指定的内存变量,继续执行程序。说明:(1)ACCEPT命令的用法同INPUT相似,但ACCEPT命令只能输入字符型数据,且键入的字符串不必加定界符。(2)按【Enter】键结束输入。数据数据库系系统及及应用用7.27.2程序设计常用命令程序设计常用命令7.2.2基本输入输出命令WAIT命令命令3格式:WAIT TO WINDOWS AT,NOWAIT TIMEOUT 功能:暂停程序运行,在屏幕上显示提示信息,等待用户从键盘上输入一个字符。说明:(1)若命令中含有选项,则在屏幕上显示提示信息,否则屏幕显示“按任意键继续.”。(2)若命令中含有TO 选项,则把输入的字符赋给指定的内存变量。(3)若使用WINDOW选项,将出现一个WAIT提示窗口。(4)若使用NOWAIT选项,系统将不等待用户按键,立即往下执行。(5)TIMEOUT选项用来设定等待时间(秒数)。数据数据库系系统及及应用用7.27.2程序设计常用命令程序设计常用命令7.2.2基本输入输出命令屏幕格式化输入输出命令屏幕格式化输入输出命令4格式:SAYGETDEFAULT功能:在屏幕指定的行、列位置输入、输出和编辑数据。说明:(1)表示数据在屏幕窗口显示的位置。(2)SAY子句用来输出数据,GET子句用来输入及编辑数据。(3)GET子句中的变量必须有初值。(4)GET子句的变量必须用READ命令来激活。数据数据库系系统及及应用用7.27.2程序设计常用命令程序设计常用命令7.2.2基本输入输出命令输出命令输出命令5格式1:?,格式2:?,功能:计算各表达式的值,并显示结果。说明:(1)表达式可以是常量、变量、函数或一般表达式。(2)?和?的区别是:?命令后面可以没有表达式,表示换行,当有时,则换行后输出表达式的值。数据数据库系系统及及应用用7.27.2程序设计常用命令程序设计常用命令7.2.3其他辅助命令程序注释命令程序注释命令1注释语句一般格式为:格式1:*格式2:NOTE 格式3:命令&说明:指任何注释文本。格式1和格式2从行首开始,且独自作为一行,格式3用于在一条命令的尾部添加注释文本。数据数据库系系统及及应用用7.27.2程序设计常用命令程序设计常用命令7.2.3其他辅助命令结束程序运行命令结束程序运行命令2格式1:RETURN功能:返回到上级程序模块。若本程序模块是以菜单方式或在命令窗口中调用执行的,则返回到交互状态。格式2:RETURN MASTER功能:返回到最上级主程序。格式3:CANCEL功能:停止程序执行,关闭所有文件,返回系统交互状态。格式4:QUIT功能:停止程序执行,关闭所有文件,释放所有内存变量,退出Visual FoxPro,返回WINDOWS操作系统。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.1结构化程序设计方法简介自顶向下、逐步求精的程序设计方法自顶向下、逐步求精的程序设计方法1结构化程序设计的主体思想是先考虑总体,后考虑细节;先考虑全局目标,后考虑局部目标。在设计过程中,它采用了自顶向下,逐层细化的方法。所谓自顶向下方法,是指设计时先从最上层开始确定系统总体目标,然后将总体目标分解为若干个功能相对独立的程序模块,进而再将每个程序模块划分为更小的子程序模块,每个子程序模块能完成一个特定的功能,并由其上级程序模块进行调用。所以,更确切地说,结构化程序设计是一个模块设计的过程。程序设计的主要任务是编写代码实现这些子模块的功能,然后将这些子模块组装起来,实现系统的总体功能。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.1结构化程序设计方法简介三种基本程序控制结构三种基本程序控制结构2顺序结构顺序结构是用顺序方式对过程分解,确定各部分的执行顺序。选择选择结构结构是用选择方式对过程分解,确定某个部分的执行条件。循环结构循环结构是用循环方式对过程分解,确定某个部分进行重复的开始和结束的条件。这三种基本结构都有一个共同的特点,那就是只有一个入口和一个出口。为了方便用户使用,有些程序设计语言还提供了其他多种形式的控制结构,如多路选择结构、直到型循环结构、步长型循环结构等。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构顺序结构顺序结构1数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构选择结构选择结构2(1)条件选择语句)条件选择语句格式:IF ELSE ENDIF 功能:首先计算条件表达式的值,当值为真时,执行,然后执行ENDIF的后续语句;当值为假时,如果有ELSE语句,则执行,然后再执行ENDIF的后续语句。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构选择结构选择结构2数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构选择结构选择结构2说明:条件表达式可以是关系表达式,也可以是逻辑表达式,使用时注意书写格式。IF与ENDIF必须成对出现,单个出现是非法的。条件语句可以嵌套,但不能出现交叉。在选择结构中,程序只能执行语句序列1或者语句序列2,两条路径汇合到一个出口,然后再执行ENDIF的后续语句。其中,语句序列1或语句序列2中可以有一个是空操作。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构选择结构选择结构2(2)多分支选择语句)多分支选择语句格式:DO CASE CASE CASE .CASE OTHERWISE ENDCASE数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构选择结构选择结构2功能:执行多分支选择结构时,系统依次检查每一个CASE语句中条件表达式的值,视其真假决定程序的走向。若遇到某个CASE语句中条件表达式的值为真,则执行该条件下的语句序列,执行完以后跳过其它条件下的语句序列,转而去执行ENDCASE的后续语句。说明:不管有几个CASE条件成立,只有最先成立的那个CASE条件所对应的命令序列被执行。如果所有CASE条件都不成立,且没有OTHERWISE子句,则直接跳出本结构。条件为关系表达式或逻辑表达式。DO CASE与ENDCASE必须成对出现,缺一不可。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构循环结构循环结构3(1)当型循环结构)当型循环结构格式:DO WHILE ENDDO功能:首先计算条件表达式的值,并判断条件是否成立。若条件表达式的值为真,即条件成立,则执行循环体中各语句。执行完循环体语句后,再根据条件决定程序的走向,直到条件不成立为止。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构循环结构循环结构3说明:DO WHILE语句为循环开始语句,语句中的可以是关系表达式或者逻辑表达式。ENDDO语句用来表示循环结构的终点,应与DO WHILE配对使用。DO WHILE与ENDDO之间的语句称为循环体,循环体是由若干条语句构成的语句系列,是循环结构程序执行的主体部分。如果第一次判断条件时,条件为假,则循环体一次都不执行。如果循环体语句序列中包含有循环短路语句LOOP,那么当遇到LOOP语句时,就结束本次循环体的执行,不再执行其后面的语句,转向DO WHILE处重新判断条件。如果循环体语句序列中包含有退出循环语句EXIT,那么当遇到EXIT时,就结束循环体语句的执行,转去执行ENDDO后面的语句。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构循环结构循环结构3说明:DO WHILE语句为循环开始语句,语句中的可以是关系表达式或者逻辑表达式。ENDDO语句用来表示循环结构的终点,应与DO WHILE配对使用。DO WHILE与ENDDO之间的语句称为循环体,循环体是由若干条语句构成的语句系列,是循环结构程序执行的主体部分。如果第一次判断条件时,条件为假,则循环体一次都不执行。如果循环体语句序列中包含有循环短路语句LOOP,那么当遇到LOOP语句时,就结束本次循环体的执行,不再执行其后面的语句,转向DO WHILE处重新判断条件。如果循环体语句序列中包含有退出循环语句EXIT,那么当遇到EXIT时,就结束循环体语句的执行,转去执行ENDDO后面的语句。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构循环结构循环结构3(2)步长型循环结构)步长型循环结构格式:FOR=TOSTEP ENDFOR|NEXT功能:这是一种计数循环语句。根据循环变量的初值、终值和步长值来确定执行循环体的次数。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构循环结构循环结构3数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构循环结构循环结构3说明:FOR语句是循环说明语句,语句中的初值、终值、步长均为数值表达式。步长值为1时,STEP 1可以省略。ENDFOR(或NEXT)语句为循环终端语句,表示循环结构的终点,应与FOR语句配对使用。FOR与ENDFOR之间是循环体语句序列。步长型循环结构的执行过程如下:进入循环首次执行FOR语句时,为循环变量设置初值。在步长型循环结构中同样可以使用LOOP语句与EXIT语句,其作用和用法与当型循环结构类似。步长型循环结构中,循环变量的值是自动改变的,不需要人为改变循环变量的值,否则会出错。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构循环结构循环结构3(3)扫描型循环结构)扫描型循环结构格式:SCAN FOR|WHILE ENDSCAN功能:对当前数据表中指定范围内符合条件的记录,逐条进行循环体内语句序列的操作。说明:在使用扫描型循环结构前必须打开相应的数据表。、的默认值同Visual FoxPro的其它数据表操作命令。SCAN为循环起始语句,ENDSCAN为循环终端语句,SCAN和ENDSCAN语句必须成对出现。在扫描型循环结构的循环体内同样可以使用LOOP和EXIT语句。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构循环结构循环结构3(4)多重循环结构)多重循环结构在一个循环结构的循环体内包含了另一个完整的循环结构称为循环的嵌套。循环嵌套对上述三种循环结构均适用。下面是一个双重步长型循环结构的嵌套形式:FOR =To STEPFOR =To STEP NEXT NEXT 数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.2Visual FoxPro基本程序结构循环结构循环结构3执行过程的顺序如下:外循环变量首先取初值,若不符合循环条件,退出循环结构,若符合循环条件,进入外层循环体。进入外循环体后,完整地执行一遍内循环。外循环变量增加步长值。根据新的外循环变量值,决定是否再次执行外循环,若是则重复第、步,否者则跳出外循环。循环嵌套的特点是:外循环执行一次,内循环执行一遍。外循环变量每取一个值,内循环变量取遍所有值。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.3过程与自定义函数过程的定义过程的定义1格式1:PROCEDURE ()RETURN TO MASTER ENDPROC格式2:PROCEDURE PARAMETERS RETURN TO MASTER ENDPROC数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.3过程与自定义函数过程的定义过程的定义1说明:每一个过程都有一个名字,即过程名。过程名必须以字母或下划线开头,可以包含字母、数字和下划线。过程定义中若使用(简称形参表),则表示该过程为有参过程。形参表用来接收调用它的主程序传来的实际参数。RETURN为返回语句,表示结束过程的执行,返回到调用本过程的上级程序。是一组语句序列,用来实现过程应完成的功能。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.3过程与自定义函数过程的调用过程的调用2格式:DO WITH 功能:调用指定名称的过程。若使用WITH子句,则调用的是有参过程。调用时将中各个参数的值分别传递给被调过程中所对应的各个参数。说明:调用过程时,如被调用者与调用者不在一个过程文件中,在调用过程前应该打开被调用过程所在的过程文件,打开命令是SET PROCEDURE TO,调用结束后还应该用CLOSE PROCEDURE命令关闭过程文件。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.3过程与自定义函数自定义函数自定义函数3(1)函数定义)函数定义格式:FUNCTION RETURN ENDFUNC说明:若含有,表示有参函数,否则为无参函数。的值为函数的返回值。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.3过程与自定义函数自定义函数自定义函数3(2)函数调用)函数调用自定义函数调用和系统函数调用方法一样,其调用格式为:自定义函数名说明:调用函数时,如被调用者与调用者不在一个过程文件中,同样需要使用打开过程命令。命令格式为:SET PROCEDURE TO。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.4变量的作用域全局变量全局变量1全局变量又称为公共变量,是在所有的程序模块中均有效的变量。全局变量可用PUBLIC命令定义。格式:PUBLIC功能:将中指定的内存变量定义为全局变量,且这些变量的初值均赋予.F.。说明:(1)全局变量应先定义后使用。(2)全局变量在整个程序中(包括调用的子程序)都有效。任何程序都可以改变它的值,在子程序中定义的全局变量在主程序中也有效。(3)全局变量在创建它的程序模块运行结束后并不释放,释放全局变量可以使用RELEASE或CLEAR ALL命令。(4)系统默认在命令窗口创建的变量均为全局变量。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.4变量的作用域局部变量局部变量2局部变量也称为本地变量,它只能在创建它的程序模块中使用,不能在上层或下层模块中使用。当建立它的程序模块运行结束时,局部变量自动释放。局部变量用LOCAL命令建立。格式:LOCAL功能:将中的变量定义为局部变量。说明:(1)局部变量要先建立后使用。(2)由于LOCAL与LOCATE前四个字母相同,所以这条命令的命令动词不能缩写。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.4变量的作用域私有变量私有变量3格式:PRIVATE ALL LIKE|EXCEPT功能:声明变量为私有变量。说明:(1)未经PRIVATE命令定义的变量,即为隐含定义的私有变量。(2)ALL短语表示当前所用的变量全部是私有变量。(3)LIKE短语表示当前变量中变量名与相匹配的变量都是私有变量。(4)EXCEPT短语表示除了与匹配的变量外都是私有变量。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.5程序调试调试器环境调试器环境1图标名称功能切换断点单击该按钮,在程序的当前语句行位置设置或取消一个断点清除所有断点清除被调试程序中已设置的所有断点打开断点对话框单击该按钮,打开断点对话框,设置断点参数继续执行当程序执行被中断时,单击该按钮可以使程序在中断处继续往下执行取消终止程序调试执行,关闭程序跟踪单击该按钮可以跟踪执行程序(包括过程及函数)中的每一行代码单步单击该按钮可以跟踪执行程序每一行代码,如果下一行代码调用了过程及函数,则过程及函数在后台运行跳出以连续方式(非单步方式)继续执行被调用模块程序的代码,然后在调用程序的调用语句的下一行处中断运行到光标处从程序的当前语句行位置执行代码直到光标处中断。光标位置可以在开始时设置,也可以在程序中断时设置数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.5程序调试调试器环境调试器环境1调试器中共有跟踪、监视、局部、调用堆栈和调试输出5个子窗口。这些子窗口的作用如下。(1)跟踪窗口:用于显示被调试程序文件的源代码及断点设置。(2)监视窗口:用于监视指定变量或表达式在程序调试执行过程中的取值变化情况。(3)局部窗口:用于显示模块程序中内存变量的名称、当前取值和类型。(4)调用堆栈窗口:用于显示当前处于执行状态的模块程序(主程序、过程或函数)。(5)调试输出窗口:用户可以在程序中设置一些DEBUGOUT命令,当程序调试执行到此命令时,计算机会计算出表达式的值,并将计算结果送入调试输出窗口。DEBUGOUT命令的格式如下:DEBUGOUT 说明:为了区别于DEBUG命令,DEBUGOUT命令动词不能简写。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.5程序调试跟踪窗口跟踪窗口2(1)打开被调试的程序文件)打开被调试的程序文件执行调试器的【文件】|【打开】菜单命令,然后在打开对话框中选定所需的程序文件。程序文件被打开后,跟踪窗口中将显示该文件的程序代码。(2)设置断点)设置断点如果在程序的某一语句行处设置一个断点,则程序运行到断点处会停止执行并等待下一步命令。数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.5程序调试监视窗口监视窗口3数据数据库系系统及及应用用7.37.3结构化程序结构化程序设计设计7.3.5程序调试调试过程调试过程4