PROGRESS编程其实很简单(一)
2010-05-17 11:07
169 查看
一、变量定义。
变量必须在第一次被使用之前定义,可以定义在程序的任何地方!但是通常为了增加程序的可读性,变量定义都放在程序的开始处!以下是变量定义的几个实例:define variable str01 as char label "DemoString" initial "hello". def var str02 like str01. def var dt01 as date extent 5. def var inte01 as inte format ">>>9".
说明,第一行:
str01 是变量名, 变量名不要与系统关键字重复,字符或者下划线开头,比如strModel,_Model ;
string 表示变量类型,本例指字符型变量,其它类似的比如integer,date,logical等 ;
label 就是后续程序中对变量的描述,比如需要用户输入这个变量值时,系统提示“DemoString" ;
initial 变量的初始值
第二行:
def和var都是简写,def是define的简写,var是variable的简写;PROGRESS支持语法简写,但是初学者最好先写全,后面有经验了再简写。
like和as的不同点是:as后面直接说明变量类型,而like后面跟另外一个变量或者字段。
第三行:
extent 5 ,表示该变量是数组变量。
第四行:
format ">>>9" 变量格式
指定变量的格式一个最大的好处就是预留宽度,这个对变量的输入或者报表的输出都很有用的。
比如年份的宽度一定是4位的,那么你就可以指定格式 format "9999"。
PROGRESS程序每行结束必须有个“.”号!!!
二、注释。
注释就是用/* ... */ ,可以嵌套,比如/*---注释1 /* 注释2 */ ---*/
三、记录的显示。
如果进入PROGRESS编程模式以后连接了数据库,那么直接显示记录的值即可,比如:for each TABLE_NAME: display TABLE_NAME. end.
/*显示TABLE_NAME所有字段所有记录*/
或者:
find first TABLE_NAME. display TABLE_NAME. /*显示TABLE_NAME第一条记录所有字段的值*/
通常显示记录值都是采用这2种方式!当然,可以按要求显示特殊的字段,比如:
FOR EACH pt_mstr WHERE pt_model BEGINS "E" NO-LOCK BREAK BY pt_price: DISP pt_model pt_price. END.
这个程序看起来真的很容易明白,简单说明:
1、where 后面带条件,比如 = <> <= >= 等等,这种关系符,对数字、日期或者字符串,都适用;
关于条件的几种组合举例:
条件1 and 条件2
( 条件1 or 条件2)and (条件3 or 条件4)
not 条件1
2、no-lock,这是关键字,你只要记住:
如果接下来的程序要对记录进行修改,那么不能加no-lock,如果不要,请加上no-lock;
3、break by ,就是按某个字段排列,默认是按这个字段的升序,如果降序则后面加上 desc,比如:
break by pt_price desc。
如果需要多次排列,那么by几次就可以,比如:
break by pt_price by pt_date
另外一个常用的显示或者更新记录的语句是find!比如:
find pt_mstr where pt_model = "mainboard" no-lock no-error. find first pt_mstr where pt_price <= 10 no-error. find last pt_mstr where pt_price <= 10 no-error.
说明:
1、where后面的条件跟for each语句类似;
2、no-lock的作用跟for each的no-lock也是一样的;
3、no-error,通常是find就加上,否则如果找不到满足条件的记录,系统会出错误提示;而实际上,通常需要在程序自己判断结果;
4、find first 就是定位第一天满足条件的记录;find last 定位最后一条满足条件的记录;
4、还有一种叫find next,就是定位当前记录的下一条;
5、find 和 find first / find last 不同的是,find后面带的条件,通常是满足TABLE的某个唯一索引。
关于for each 和 find,这章你只要了解到这里就OK了!
四、判断。
判断最简单了,就是一个if 条件 then ... else ...,比如:DEFINE VAR str1 AS CHAR INITIAL "CPU". IF str1="CPU" THEN DISP "cpu". ELSE DISP "NOT cpu".
当然,这个”条件“可能有很复杂的组合。如果,涉及到的动作比较多,那么做法是用do: ... end.,比如
DEFINE VAR str1 AS CHAR INITIAL "CPU". IF str1="CPU" THEN DO: str1="My CPU". DISP "cpu". END. ELSE DO: str1="My memory". DISP "NOT cpu". END. DISP str1.
if 支持嵌套,怎么嵌套?你自己会了!不是吗?
五、循环。
PROGRESS的循环功能实在令人不敢恭维,没有when 没有while,没有loop、for什么的,只有一个repeat!不过,用好了这个repeat,一样实现任何功能。
通常实现循环的模式:
repeat: /*处理事务*/ if 条件 then leave. /* 退出循环 */ end.
现在,你试试用find 和 repeat 实现 for each的功能!
REPEAT: FIND NEXT pt_mstr. DISP pt_mstr WITH 2 COLUMNS. END.
或
DEF VAR i AS INTEGER. FOR EACH pt_mstr WHERE pt_price > 10 NO-LOCK. i = i + 1. DISP pt_part pt_price WITH DOWN FRAME a. IF i > 200 THEN LEAVE. END.
六、赋值和计算。
+ - * / ,就是 加 减 乘 除了!比如:ttl_amoount = ttl_ammount + dtl_amount. x_a = x_b / x_c. str_ttl = "I'm" + "sure!". dt01 = today - 1. dt01 = 3/22/2005. /* 日期 */
当然,日期和字符串不能做乘法或者除法!
七、其它零星的语法。
显示:display 简写disp
退出编程模式:
quit
执行UNIX命令:
unix COMMAND
好了,这章你学会了,如果熟悉数据库表和字段的结构,你也大概能看任何东西了,甚至做一些常规的统计也肯定没问题!
相关文章推荐
- PROGRESS编程其实很简单(二)
- PROGRESS编程其实很简单(三)
- 编程其实很简单
- C++多任务编程简明教程 (1) - C++的多任务其实很简单
- iOS界面编程-UIProgressView
- Windows编程中的映射模式和坐标转换
- Java咖啡馆(1)——叹咖啡-Java基础-Java-编程开发
- 【编程游戏】贺岁霓虹灯。(参观328楼wujinjian2008n的霓虹灯)
- 学习ipad编程的一些资料
- python 多线程编程的有趣的现象02
- 一些有趣的编程名言
- 推荐好看的编程字体
- Java图形编程入门(连载1)
- 网络编程--tcp传输
- PHP OPP机制和模式简介(抽象类、接口和契约式编程)
- 并行编程的设计模式
- 编程基础-回调
- Java Socket(四)编程实现基于 TCP 的 Socket 通信
- 第八章:iOS网络应用编程
- 网络编程知识巩固(一)