PB的数据窗口操作

上传人:汽*** 文档编号:563669139 上传时间:2022-12-14 格式:DOCX 页数:6 大小:21.93KB
返回 下载 相关 举报
PB的数据窗口操作_第1页
第1页 / 共6页
PB的数据窗口操作_第2页
第2页 / 共6页
PB的数据窗口操作_第3页
第3页 / 共6页
PB的数据窗口操作_第4页
第4页 / 共6页
PB的数据窗口操作_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《PB的数据窗口操作》由会员分享,可在线阅读,更多相关《PB的数据窗口操作(6页珍藏版)》请在金锄头文库上搜索。

1、Composite复合报表型的就是可以由几个DW组合成的Crosstab交叉报表型.这个很少用.Freeform自由风格,就是里面的列可以自已改变的.常用Graph统计图,你知道的Grid网格,类似EXCEL的最常用Group分组的.有分组小计要用的那种常用Label标签的就是一个大格子一个大格子排列显示的那种N-Up分栏显示的这个少用.Tabular列表的,这个列表不是太好用这个也少用SetTransObject语法:dwcontrol.SetTransObject ( transaction )功能:给数据窗口或者datastore控件dwcontrol设置事务对象transaction,

2、缺省事务对象是SQLCA。 返回值:成功设置事务对象则返回1执行过程中发生了错误则返回-1,有任意参数为Null时返回Null。Retrieve语法: dwcontrol.Retrieve ( , argument, argument . . . )功能:使用数据窗口控件的当前事务对象检索数据库中的数据。如果数据窗口控件对应的数据窗口对象定 义了检索参数,则应该在该函数中指定检索参数,参数的个数和数据窗口对象的检索变量个数相等,对应 的数据类型相兼容。返回值:返回数据窗口控件主缓存区(PrimaryBuffer)中的记录数,如果检索数据时发生错误则返回-1, 如果任意参数为 Null 则返回

3、Null*该函数的参数和数据窗口对象定义的参数的顺序要相同,类型要兼容。个数不能少于数据窗口对象定义的 参数,即可以等于和多于数据窗口对象定义的参数,多的参数忽略。DeleteRow语法: dwcontrol.DeleteRow ( row )功能:删除数据窗口 dwcontrol中的第row行数据,如果row为0则表示删除当前行的数据。返回值:执行成功则返回1执行错误则返回-1,如果任意参数为Null则返回Null。*该函数执行后只是将被删除的数据从数据窗口的主缓存区移放到Deleted缓冲区,在数据库中并没有真 正删除数据,当正确执行了 Update函数并且使用commit语句提交了事务后

4、,才真正从数据库中删除该 数据InsertRow语法:dwcontrol.InsertRow ( row )功能:在数据窗口 dwcontrol的第row行前插入一行空白数据。当指定row为0时,表示在当前行之前 插入一行空白数据。返回值:返回插入的数据的行号,如果执行过程中发生错误则返回-1,如果任意参数为 Null 则返回 NullUpdate语法: dwcontrol.Update ( accept , resetflag )功能:提交数据窗口或者datastore中的数据。如果accept为True,表示在提交数据之前自动执行 AccpetText函数,否则不执行该函数,该参数缺省为T

5、rue;如果resetflag为True,表示数据提交后 自动清除修改标识,该参数缺省为 True。返回值:执行成功则返回1发生错误则返回-1如果dwcontrol为Null则返回NullAcceptText语法: dwcontrol.AcceptText ( ) 功能:该函数执行时,首先对当前编辑框中的内容进行对应字段的校验规则,能够通过校验规则,则保存 在对应字段中,否则显示校验信息提示错误。需要执行该函数的原因是,当在某字段上的编辑框中输入内 容而没有移动光标到别的字段上时,其他控件获得焦点,此时编辑框中的内容不能被保存到字段中,所以 就应该在数据窗口失去焦点时执行该函数。返回值:执行成

6、功则返回1执行过程中发生错误则返回-1如果dwcontrol为Null则返回Null。*该函数在数据窗口的ItemChanged事件中不起作用,因为项目改变是发生在接受编辑框中内容之后ModifiedCount语法: dwcontrol.ModifiedCount ( )功能:获取数据窗口或者 Datastore 中被修改过但还没有提交到数据库中的记录数。返回值:返回 long 类型的数据窗口控件中被修改过的记录数,如果没有记录被修改过或者修改后都已经保 存到了数据库中则返回0,执行过程中如果发生错误则返回-1如果dwcontrol为Null则返回Null。*该函数获得的修改过的记录数包括主缓

7、存区和Filter缓存区的被修改过的和新添加到数据窗口中的记录 数DeletedCount语法: dwcontrol.DeletedCount ( ) 功能:获取数据窗口控件或者 datastore 控件 dwcontrol 中被删除的记录数。返回值:返回 long 类型的已经被删除但还没有提交到数据库中的记录数,如果执行过程中发生了错误则返 回-1,如果dwcontrol为Null则返回Null,如果没有删除过记录则返回0RowsMove 它可以将数据从一个缓冲区移动到另外缓冲区中。该函数的语法是:dwcontrol.RowsMove ( startrow, endrow, movebuff

8、er, targetdw, beforerow, targetbuffer ) 其中,dwcont rol是进行移动操作的源数据窗口; sta rtrow和end row是要移动数据的范围(包括这两个 行号的数据); movebuffer 指要从哪个缓存区移出数据,可以是 Primary!、Delete!、Filter!; targetdw 是目标数据窗口控件名称; beforerow 表示在目标数据窗口的哪一行之前插入移入的数据,如果该数值比 目标数据窗口的行数大,则在最后插入移入的数据;targetbuffer是目标缓存区,取值同movebuffer 一样。GetItemStatus 和

9、SetItemStatus使用函数 dwcontrol.GetItemStatus ( row, column, Primary! )可以获取该缓冲区内指定单元的状态, 当参数 column 为 0 时,表示读取整个行的修改状态。有以下状态。NotModified! :指定单元的数据和原始数据相同,没有修改过。DataModified!:指定单元的数据和原始数据不同,修改过。New! :该数据行是新增加的,但还没有在该行上输入数据。NewModified!:该数据行是新增加的,并且已经在该行上录入了数据。这些修改标识都是由数据窗口自动维护的,一般情况下没有必要编写脚本修改这些标记,但并不是说就

10、不能修改。PowerBuilder提供了函数SetltemStatus,它的语法是: dwcontrol.SetItemStatus ( row, column, dwbuffer, status )其中,row参数指定将要修改状态的行;column参数指定将要修改状态的列(可以是整型的列号,也可以 是string类型的列名),当列号为0时表示要修改row指定的整行的状态;dwbuffer指定要修改哪个缓 冲区(肯定不能是original), status为上面的四个取值中的一个,但不是任意的取值,因为有些状态不能 用该函数设置成另外一种状态,必须是能够转换的状态。下面列出了能够转换的状态。期

11、望的状态 New! NewModified! DataModified! NotModified!当前状态New! Yes Yes NoNewModified! No Yes NewDataModified! NewModified! Yes YesNotModified! Yes Yes Yes 表中的Yes表示可以使用SetltemStatus进行该状态设置,No表示不会产生预期的状态,如果标明了某 个特定的状态,则说明是新的状态,而不是期望的状态。例如,数据窗口 dw_1的第1行第1列的当前状 态为DataModified!,使用函数dw_1.SetItemStatus(1,1,New!

12、)后,第1行第1列的状态改变为 NewModified!。同样对于该数据窗口 dw_1,如果使用函数dw_1.SetItemStatus(1,1,NotModified!), 则会将其状态改变为NotModified!。当从一种状态不允许转变到另一种状态时,可以修改成其他一个中间 状态,然后再进行一次转换。例如,要从new!改成NotModified,应该首先转换到DataModified!GetItemX读取数据窗口中的数据dwcontrol.GetItemX( row, column , dwbuffer, originalvalue )其中的X可以替换成Date、DateTime、Dec

13、imal、Numbe r、St ring、Time,所以读取数据的函数有 6个。参数row表示要读取哪行的数据,是一个long类型数值。column代表列,可以是st ring型的列 名,也可以是整型的列号。dwbuffer是DWBuffer枚举型,取值Primary!、Delete! Filter!分别代表 主缓冲区、删除缓冲区和过滤缓冲区。originalvalue为Boolean型,表示是否读取最近一次检索时检索 到的初始值,当指定dwbuffer时必须指定该参数,该参数和dwbuffer都是可选的。函数正确执行则返 回对应类型的数据,执行过程中发生错误则返回空值(),任何参数为 Nul

14、l 则返回 NullSetItem 和 SetText函数SetItem的语法格式是:dwcontrol.SetItem ( row, column, value )各个参数的含义如下。dwcontrol:数据窗口或datastore控件名称。row :要设置的数据所在行。column:要设置的数据所在的列。可以用整型列号,也可以用st ring型列名。value :要设置的值,应该和要设置的列的类型一致。函数正确执行则返回 1,这时数据窗口中 row 行 column 列显示的数据是刚刚用该函数设定的数据,如果 函数执行过程中发生错误则返回-1。注意,该函数执行时仅仅检查函数中指定数据的类型

15、和字段的类型是 否一致,不会进行有效性校验,包括在数据窗口中设置的校验规则、在ItemChanged事件中编写的校验 规则、在 ItemChanged 调用的校验规则都不会执行。函数 SetText 的语法格式是:integer dwcontrol.SetText ( string text ) 功能是设置当前编辑框中的内容。注意,当编辑框离开当前单元时要进行有效性校验,如果校验数据正确, 则当前字段接受该数据,否则触发ItemE rror事件。所以,可以使用该函数给带有校验规则的字段设置数 据。EG: int li_idw_1.SetColumn(name)/使 name 列成为当前列/使第 I 行成为当前行/向当前编辑框中写入内容/选中性别列,保证最后一个也要通过校验规则For li_i = 1 To dw_1.RowCount() dw_1.SetRow(li_i)dw_1.SetText(屁)Nextdw_1.SetColumn(sex)SetColumn、SetRow 和 GetColumn、GetRow 和 GetClickedColumn、GetClickedRow 和 GetColumnName设置当前列integer dwcontrol.SetColumn ( string column)integer dwcont

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 学术论文 > 其它学术论文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号