翻新时间:2013-12-18
PowerBuilder数据窗口编程技巧
PowerBuilder数据窗口编程技巧 PowerBuilder数据窗口编程技巧 信息技术论文 更新:2006-4-8 阅读: PowerBuilder数据窗口编程技巧
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列,我们可使用计算列:CumulativeSum(Quantity 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、如何在DataWindow的SQL语法中不使用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'。即可达到这项功能。
联系地址:炮兵学院二系十队 230031
电话:5578721 BP 3401188?/FONT>5169
下载文档
网友最新关注
- 小插曲
- 我爱春天
- 日记一则(起点)
- 仙人球
- 早晨
- 春天来了
- 小小的我
- 晨练
- 橘子
- 一次有趣的游戏
- 春天
- 家乡变了
- 苹果
- 扫地
- 我是一片云
- 国家公务员的入党申请例文
- 2011年企业管理人员的入党申请书
- 大学生村官的入党申请书例文
- 青年大学生的入党申请书模板
- 12月研究生的最新入党申请
- 计算机专业学生的入党申请书样文
- 公安局人民警察的入党申请
- 金融系统职员的入党申请
- 普通大学生的入党申请书样稿
- 12月最新工人入党申请书例文
- 陆军学院军校学生的入党申请书
- 银行团干部职员的入党申请
- 电视从业人员的入党申请书
- 11月中旬大学生入党申请书参考
- 大学生经典入党申请书范文
- 音乐教学的误区和对策
- 论扬琴的基础教学
- 浅析高校合唱训练与其作用
- 浅谈钢琴演奏的艺术个性
- 张大龙音乐作品的解析
- 浅谈山东筝派与浙江筝派的异同
- 关于山区公路边坡滑坡的原因及其处理方案探讨
- “白改黑”城市道路改造技术探讨
- 论流行音乐的审美导向
- 把握学生的心理特征重视音乐情感的体验
- 如何提高儿童练习古筝的兴趣及效率
- 中学音乐教学中个性培养的研究
- 浅谈歌唱者的临场心态
- 浅谈现代舞及其在我国发展现状的思考
- 论中学音乐教师职业倦怠的原因及对策思考
- 《我不能失信》教学设计2
- 《我不能失信》教材简说
- 《秋天的雨》第一课时教学设计1
- 《奇怪的大石头》教学建议
- 《快乐的节日》教学谈--月儿弯弯
- 《我不能失信》教学建议
- 《快乐的节日》研究课教学设计
- 《我不能失信》教学设计1
- 《纸船和风筝》教学设计
- 《奇怪的大石头》教学设计2
- 《看雪》
- 《风筝》教学设计7
- 《风筝》教学设计6
- 《七颗钻石》教学设想
- 《画杨桃》一文的教学案例与反思