工学
RSS阅读器
 您现在的位置: 在职教育交流中心 >> 论文写作 >> 计算机 >> 计算机应用 >> 论文正文

PowerBuilder数据窗口编程技巧

作者:佚名    论文来源:在职教育交流中心    点击数:    更新时间:2007-5-21
 

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

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

Quantity Running Total

5,000 5,000

2,500 7,500

3,000 10,500

12,000 22,500

对于Running Total列,我们可使用计算列:CumulativeSumQuantity for all),即可达到逐渐递增求和的功能。

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

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

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

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

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

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

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

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

ls_Find = "datetime_col = DateTime ('1/1/1999')"

2)当要查找的日期条件是一个变量时使用如下的表达式:

ls_Find = "datetime_col = DateTime ('" + ls_Date + "')"

3 当要查找的日期条件是一个DateTime数据类型时使用如下表达式:

ls_Find = "datetime_col = DateTime '" + String (ldt_DateTime) + "')"

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

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

dw_1.Object.address.Visible = 0

dw_1.Object.address.Visible = False

dw_1.Object.address.Visible = 'No'

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

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

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

FOR ll_RowOn = 1 TO dw_1.RowCount()

dw_1.DeleteRow(ll_RowOn)

NEXT

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

dw_1.RowsMove(dw_1, 1, dw_1.RowCount,

Primary!, dw_1, 1, Delete!)

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

6、如何在DataWindowSQL语法中不使用SELECT DISTINCT实现删除重复的行

首先对你要显示唯一值的列进行排序:"money",然后增加如下过滤字符串:" money < > money [-1] or GetRow () = 1"

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

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

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

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

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

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

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

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

IF (GetRow() = First(GetRow() FOR Page), 1, 0) // 1 为当前页的第一行

IF (GetRow() < > 1 AND GetRow() = Last(GetRow() FOR Page), 1, 0)

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

由此例可知,在Footer Band中设置如下计算列表达式:'Rows ' + String(First(GetRow() FOR Page)) + ' to ' + String(Last(GetRow() FOR Page)) + ' are displayed'。即可达到这项功能。

 

【声明】本网站刊载的资料由网友提供分享 资料内容纯属作者个人观点,不表示本网同意其说法或描述,仅为提供更多信息,也不构成任何建议。网友转载请注明原作者姓名及出处。如有侵犯到您的版权,请与我们联系
·PowerBuilder数据窗口编程技巧· 【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】    
    
  • 上一篇论文:
  •  
        
  • 下一篇论文:
  •  
    相关论文
    基于动态网页——ASP的WEB数据库开发
    ASP技术访问WEB数据库
    完整的Windows 2000服务配置
    互联网时代的WebGIS开发
    基于网格的面向专业内容的Web信息检索体系结…
    Windows 2000系统编程——进程的创建
    网友评论:
    (只显示最新10条。评论内容只代表网友观点!)
    早上8:30-下午5:30
    全国客服热线: 010-84639241
    客服QQ: 10015411 / 173799180
    客服Email: edufo@163.com
      QQ交流群: 5379191 / 5371551
    网站介绍 |  联系我们 | 加盟合作 | 友情链接 | 广告服务 | 诚聘英才 | 网站地图 | 免责声明
    不良信息
    举报中心
    在职教育交流中心 版权所有 TEL:010-84639241 京ICP备06028089
    Copyright © 1998 - 2007 EDUFO Inc. All Rights Reserved
    网络110
    报警服务