在编制管理信息应用系统中,一般都会遇到一个共同问题,那就是如何根据不同情况去控制表中的数据列,比如对于同一DATAWINDOW不同的用户有不同的操作(如对于数据录入人员可以更改数据,而对于查询人员一般不能更改数据),下面就以一个简单的工资表为例来说明利用PB如何在DATAWINDOW中控制列的修改方式。
工资表基本列如下:
代码 姓名 工作时间 基础工资 浮动工资 岗位工资 知识分子补贴 其它工资
code name workdata basesa movesa stationsa bt othersa
char varchar char decimal decimal decimal decimal deciaml
在PB中有两种方式可控制列属性,一是静态方式,另一种是动态方式实现。所谓静态方式就是在列的属性上通过选项实现。所谓动态方式就是利用编程实现。
现分别给予介绍:
一、静态方法
(1)在datawindow中选中某列后点MOUSE右键,“properities”后系统弹出一标签,选中“Edit”标签,将“Display Only”选项制为有较;
(2)或者选中“Expression”标签,在“Protect Express”中填入“1”;
(3)或者选中“Expression”标签,在“Protect Express”中填入条件表达式,如工作时间不满一年的人员不能修改,则写入
“if (daysafter(date(workdate),today()) <= 365,1,0)”;
(4)在datawindow中,将某列的Tab Order值制为0,则该列因得不到焦点而不能被修改;
(5)在DataWindow Painter 状态下选取Row
本文介绍了在PowerBuilder中控制数据窗口列的修改属性的方法,包括静态方式和动态方式。静态方式主要通过设置列属性实现,动态方式则通过编程实现。详细讲解了如何根据用户角色或特定条件来控制数据的读写权限,如设置Display Only、保护表达式、Tab Order等。
订阅专栏 解锁全文
894

被折叠的 条评论
为什么被折叠?



