PowerBuilder(以下简称PB)是Powersoft公司(已被Sybase收购)推出的基于客户机/服务器体系结构的强有力的开发工具,自问世以来深受开发人员的好评。Datawindow是PB中获取专利技术的控件,它对数据的处理方法相当简洁,数据窗口能处理各种显示格式、进行报表打印,对复杂的嵌套报表同样处理自如。
数据窗口的处理机制首先是根据所需的显示方式将数据源表中的域设计好,在运行时将所要的数据从数据库服务器上下载到客户机上处理,然后将更改后的数据进行提交(Commit)或回滚(Rollback)。这种处理机制大大降低了数据的传输量,减轻了网络的负担,也提高了数据的处理速度。充分利用数据窗口的特点,可达到事半功倍的效果,但是如果有些问题不加注意就会出现意想不到的错误。
几个函数
1. AcceptText()
AcceptText()函数的功能是将数据窗口当前编辑的数据转移到数据窗口的缓冲区中。程序通常在关闭窗口及其他情况下判断是否改变了当前数据。如果已改变数据,应提示用户保存。这就杜绝了用户在偶然的情况下丢失更改数据的现象。一般用ModifiedCount和DeletedCount函数判断数据是否改变。
PB在处理数据窗口时,对应开辟了四个数据缓冲区,分别为Primary Buffer、Deleted Buffer、Filter Buffer、SortBuffer,其中Deleted Buffer存放被删除的记录,Filter Buffer存放被过滤的记录,Sort Buffer存放排序的记录,Primary Buffer存放其他记录。函数ModifiedCount从Primary and Filter Buffers中取数据进行判断,DeletedCount则从Deleted Buffer中取数据进行判断。
PB在接受用户输入时设置了一个浮动编辑框,用户输入或更改的内容并不直接进入Primary Buffer,而是在用户输入完后进入下一个域时,PB首先对它进行有效性检测,通过后转入Primary Buffer。如果只改变一项数据就关闭窗口则相关数据并没有进入Primary Buffer,系统判断ModifiedCount()为0,所以不会提示保存数据。用AcceptText()函数就可以将浮动编辑框中的数据转入缓冲区中,在相应的程序段前加上Accepttext(),问题就解决了。
2. FindRequired()
在实际应用中经常需要限制表中一些域的属性,例如银行客户表中账号就不能为Null。在提交数据前检查是否将必须输入的数据都赋值是一个很好的编程习惯。FindRequired函数可以解决此问题,它通过对数据窗口中数据的检查,将数据窗口中域的属性为Required,而并未赋值的域(包括相应的行、列)找出来。
为了利用此函数,在构造数据窗口时就要注意将表中具有NOT NULL属性的数据列设为Required(方法为:在数据窗口相应域上按鼠标右键或双击左键,弹出Column Object 框,选Edit页,将Required前的框选中,按Ok钮即可)。在相应事件中插入下列程序:
long ror=1 //行数赋1
integer colnbr=0 //列数赋0
string colname //用来存储列名
mle_required.Text = "" //窗口中的多行编辑控件,用来存储找到域的行、列号
DO WHILE row <> 0
colnbr++ //继续找下一列
IF dw_1.FindRequired(Primary!,row, colnbr,colname, FALSE) < 0 THEN EXIT
//若程序出错则返回
IF row <> 0 THEN
mle_required.Text = mle_required.Text + String(row) + "~t" &+ colname + "~r~n" //保存查出的行、列号
END IF
//当ROW返回为 0 则意味再没有查出,跳出循环
LOOP
程序执行完后,多行编辑框中显示的为出错的地方,用户根据提示可以轻易地更改。
FindRequired函数中的Row、Colnbr参数能自动增加或重置,Colname用来存放列的字符名。
数据的突出显示及保护:程序运行中,用户希望显示的数据具有明显的区分,例如学生的成绩(不及格的分数要用红色显示),有些数
据必须只能显示,不能让用户修改;还有些数据在有些时候可以修改,有些时候不能修改等。以上情况可归结为两点: