首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > PB >

PowerBuilder数据窗口编程技巧,该怎么处理

2012-09-17 
PowerBuilder数据窗口编程技巧PowerBuilder取得巨大成就的原因就是有功能强大和灵活多变的Datawindow对象,

PowerBuilder数据窗口编程技巧
PowerBuilder取得巨大成就的原因就是有功能强大和灵活多变的Datawindow对象,本人用PowerBuilder开发过一段时间后,总结出一些技巧,以供广大的PB开发者借鉴使用。

1、如何创建一个具有逐渐递增求和功能的表,如下形式:

QuantityRunningTotal

5,0005,000

2,5007,500

3,00010,500

12,00022,500

对于RunningTotal列,我们可使用计算列:CumulativeSum,即可达到逐渐递增求和的功能。

2、数据窗口的数据送缓冲区之前确认的四个步骤

假如我们不清楚数据窗口中的数据在送入缓冲区之前所发生的一切,在保存数据时就不明白错误发生的原因,找不出错误的根源。

PB首先判定数据类型是否正确。如不正确则触发ItemError事件。

接着判定数据是否符合有效性规则。如不符合有效性规则,同样触发ItemError事件。

然后判定是否有数据被改动。

最后判定数据是否通过ItemChanged事件,假如数据和ItemChanged相斥,将触发ItemError事件。

3、如何在DataWindow中用数据类型为Datetime的列为条件进行查寻

当要查找的日期条件是一常数时使用如下表达式:

ls_Find=“datetime_col=DateTime“

4、设置数据窗口Boolean型属性的三种方法

PowerBuilder提供了三种方法设置数据窗口的布尔型属性,分别是True/False,1/0,/。例如:

dw_1.Object.address.Visible=0

dw_1.Object.address.Visible=False

dw_1.Object.address.Visible=



PowerBuilder在处理时以字符串的形式保存属性,而不考虑属性值是布尔型、长整型或是字符型。为了进一步理解,可以导出一个数据窗口并查看它的原码,可以发现即使是列的颜色属性它也是使用带双引号的数字来表达。

5、如何在数据窗口中快速删除多行

在开发过程中可能经常有要进行多行删除的操作,一般都使用循环语句进行操作:

FORll_RowOn=1TOdw_1.RowCount

dw_1.DeleteRow

NEXT

这里提供一个快速的删除方法把要删除的行从主缓冲区中移到删除缓冲区中。例如,删除缓冲区中所有的行:

dw_1.RowsMove

但需注重的是不要忘了过滤的行在不同的缓冲区中。

6、如何在DataWindow的SQL语法中不使用SELECTDISTINCT实现删除重复的行

首先对你要显示唯一值的列进行排序:“money“,然后增加如下过滤字符串:“moneymoneyorGetRow=1“

7、如何在分组形式的DataWindow中分别显示各组的行号

当我们为Datawindow的每一行显示行号时,可以简单的放一个表达式为GetRow计算列。但是对于分组的Datawindow,要分别显示各组的行号,则应使用表达式为GetRow-FirstforGroup1)+1的计算列。

8、如何改变列的字体颜色,以提醒用户此列已做修改

在列的Color属性中,输入如下表达式IF,RGB)。在这个条件中,假如此列已改变,则显示红色字体,否则显示黑色字体。这个表达式主要用column_namecolumn_name.Original比较当前列的值和原始列的值是否相同来达到判定的目的。

9、在数据窗口中移走行,但不是去做过滤或删除操作

RowsDiscard函数可做到这一点,它在数据窗口中执行移除工作,但被移走的行它不可被删除或做任何修改性的保存。

10、如何在多行显示的DataWindow中的FooterBand中显示当前数据的首行和最后行的行号

我们先看两个计算列的表达式的例子:

IF=FirstFORPage),1,0)//1为当前页的第一行

IF1ANDGetRow=LastFORPage),1,0)

//1为当前页的最后一行

由此例可知,在FooterBand中设置如下计算列表达式:+StringFORPage))++StringFORPage))+。即可达到这项功能。


[解决办法]
支持分享!
[解决办法]
band()...
[解决办法]
MARK
[解决办法]
支持分享!

热点排行