`
JAVA海洋
  • 浏览: 615569 次
  • 性别: Icon_minigender_1
  • 来自: 太原
社区版块
存档分类
最新评论

PB动态报表格式自由定义的实现

阅读更多
  在通常的Server/Client方式MIS开发中,总是有没完没了的报表需要制作,调试报表花费的时间也是最多而且乏味,还常常不能满足客户的要求。要是能够让用户自己调整报表的格式和内容,然后将它保存下来,程序下次启动时它自动调用保存了的报表格式那有多好。本人通过如下方法最终实现了用的要求。
PB(PowerBuilder)有一种以PSR结尾的特殊的保存报表的文件格式(本文简称作PSR文件)。根据数据窗口可以直接读取PSR文件生成报表的原理,程序通过生成PSR文件,实现动态报表格式的保存。

  一、实现原理:

  PB中的报表其实就相当于是数据窗口。

  第一步,动态报表的实现。通过设置数据窗口对象(dataobject)中文本、列等的Resizeable和moveable属性为1来实现对象位置的拖动控制,通过数据窗口的Modify函数实现对象值的更改(包括增加和删除)。

  第二步,报表格式的保存。在一个应用当中,数据窗口对象的名称总是唯一的,将每一个数据窗口对象转化成PSR文件存于数据库表中。在窗口打开时,程序先校验报表格式是否存在。如果存在,先将报表格式读取出来放在一个临时文件当中,然后设置数据窗口(datawindow)的数据对象(dataobject)为这个报表文件,然后提取数据;如果不存在,直接提取数据即可。

  二、实现过程:

   1、建立一个数据库表用以保存报表格式文件。
表名:dyn_report
Dwobject Varchar2(20) 数据窗口对象名称 Primary key
Rptitle Varchar2(80) 报表的标题名称
Memo Long raw 报表格式

   2、建立一个窗口w_temp。 定义实例变量如下:

   string is_dwtype,is_dwobject //保存报表中对象的类型及名称

控件名称 控件含义
Dw_print 数据窗口对象
Cb_exit 退出按钮
Cb_savereport 报表格式保存按钮
  
   3、在窗口的OPEN事件中加入如下代码, 校验报表格式是否存在,如果存在读取定义好的报表格式到数据窗口。

  blob emp_pic
   long ll_handle
   string ls_dwobject,ls_reportfile,ls_path
   ls_dwobject = dw_print.dataobject
   //判断是否存在该数据窗口的报表格式
   select count(*) into:ll_count from dyn_report where dwobject =:ls_dwobject;
   if ll_count>0 then
     //读取报表格式文件到大文本变量
     selectblob memo into:emp_pic from dyn_report where dwobject =:ls_dwobject;
     //创建psr临时文件到硬盘
     ls_reportfile = '\temp7089.psr'
     ll_handle = FileOpen(is_reportfile,StreamMode!,write!,LockWrite!,Replace!)
     FileWrite(ll_handle,emp_pic)
     FileClose(ll_handle)
     dw_print.dataobject = ls_reportfile
     dw_print.settransobject(sqlca)
   else
     Dw_print.settransobject(sqlca)
   End if
   Dw_print.retrieve()
   4、报表格式的保存。通过Cb_savereport按钮的clicked实现。
   string ls_filename
   long ll_count
   blob Emp_id_pic
   ls_filename = "temp70201.psr"
   //保存报表格式到硬盘临时文件
   dw_print.saveas(ls_filename,PSReport! ,false)
   sqlca.autocommit = true
   select count(*) into :ll_count from dyn_report where dwobject =:is_dwobject;
   if ll_count =0 then
     insert into dyn_report(dwobject,rptitle)
     values(:is_dwobject,:ls_filename,:ls_path);
   end if
   //从硬盘临时文件读取数据保存到数据库表中
   emp_id_pic = of_readbmpfile(ls_filename)//该函数将二进制文件内容读到大文本对象中
   //更新数据库
   UPDATEBLOB dyn_report SET memo = :Emp_id_pic where dwobject = :is_dwobject;
   sqlca.autocommit = false

  5、动态报表的实现。通过数据窗口dw_print的clicked事件捕获数据窗口中对象,并将对象名存放在实现变量is_dwobject中,为下一步修改报表作准备。

   string ls_type,ls_dwoname
   //得到对象类型和名称
   ls_type = trim(upper(dwo.type))
   ls_dwoname = trim(dwo.name)
   is_dwtype = ls_type
   choose case ls_type
     case "TEXT","CommandButton","GROUPBOX"
       is_dwobject = ls_dwoname
       //设置为可以拖动和改变大小,其它类同
       this.modify(ls_dwoname+".Resizeable='"+"1'")
       this.modify(ls_dwoname+".moveable="+"1")
     case "LINE" //直线对象不能通过设置Resizeable和moveable属性进行调整,必须通过其它路径
       is_dwobject = ls_dwoname
     case "RECTANGLE","ELLIPSE","GRAPH","BITMAP"
       is_dwobject = ls_dwoname
       this.modify(ls_dwoname+".Resizeable='"+"1'")
       this.modify(ls_dwoname+".moveable='"+"1'")
     case "COLUMN","COMPUTE"
       is_dwobject = ls_dwoname
       this.modify(ls_dwoname+".Resizeable='"+"1'")
       this.modify(ls_dwoname+".moveable='"+"1'")
   end choose


   然后再通过modify()函数可以实现基本的动态报表操作,这一类的文章较多,PB中也有大量的例子可直接使用,在此这不再累述。

   6、在cb_exit按钮的clicked()事件中加入:close(parent)。

   7、在应用的open事件中加入: open(w_temp)。然后保存并运行,大功告成啦!

   8、本程序在PB7.0加Oracle8.05下调试通过。
分享到:
评论

相关推荐

    PB动态报表格式自由定义的实现.txt

    ### PB 动态报表格式自由定义的实现 在企业信息系统(MIS)的开发过程中,报表设计是一项必不可少但又相对繁琐的工作。特别是在采用 Server/Client 架构的应用系统中,由于用户需求多样化且不断变化,如何高效地...

    30fb3e48_PB动态报表格式自由定义的实现_pb_

    在通常的Server/Client方式MIS开发中,总是有没完没了的报表需要制作,调试报表花费的时间也是最多而且乏味,还常常...根据数据窗口可以直接读取PSR文件生成报表的原理,程序通过生成PSR文件,实现动态报表格式的保存。

    PB动态报表源码,报表格式自由定义的实现

    在企业级应用中,报表通常需要根据不同的业务需求进行定制,因此,能够自由定义报表格式的功能至关重要。本资源提供了PB环境下实现动态报表的相关源码,通过深入学习和理解这些代码,开发者可以掌握如何构建具有高度...

    pb自由报表

    在实际开发中,开发者会结合PowerBuilder的数据窗口对象和这些图形资源,通过编写PB源代码来实现动态数据检索、数据过滤、排序、分组、计算以及自定义打印等报表功能。同时,还可以利用PowerBuilder的脚本语言...

    pb freeform报表实现英文换行自动行高.zip

    在PB (PowerBuilder) 开发环境中,DataWindow 是一个强大的数据展示组件,它允许开发者创建各种类型的报表,包括表格、自由格式(Freeform)等。本压缩包"pb freeform报表实现英文换行自动行高.zip"提供的内容是关于...

    PB自定义报表程序

    源代码的开放性意味着用户可以根据具体业务需求自由调整报表格式,增加新的计算字段,或者定制复杂的过滤条件。 此外,对于PB自定义报表程序的使用,还需要了解PB的开发环境和基本语法,如事件驱动编程模型,以及...

    Pb报表设计、自定义报表

    PB报表设计与自定义报表是PowerBuilder(简称PB)开发中的关键组成部分,它允许开发者创建交互式的、数据驱动的报表,以满足各种业务需求。在PB11.5编程环境中,用户可以利用其强大的报表工具来构建复杂的数据展示,...

    在PB开发中利用PSR文件实现打印位置自由调整

    ### 在PB开发中利用PSR文件实现打印位置自由调整 #### 概述 在PowerBuilder(简称PB)的开发过程中,经常会遇到用户需要根据实际需求调整打印内容的位置、格式等情况。传统的做法是开发者通过修改源代码来调整打印...

    在PB中使用的第三方报表

    描述中提到的“可以轻松实现用户自定义报表,提供标准的预览界面,解决了PB中预览效果不佳和不能由用户自定义的毛病”,意味着这些第三方报表工具提供了更加灵活的报表设计界面,让用户能够根据需求自由定制报表布局...

    PB FrameWork和Super DW

    此工具可以使用PB的开发环境,把数窗方便的存储到数据库中或者PBL中,也可以在PBL和数据库间自由转换,也可以脱离数据库使用,不像其他自定义报表一样,总是跟着PB走,即使开发的再好也不如PB本身。 2.由于数窗...

    pb6.5的dw 经典 了解dw的原理

    DataControl用于控制DataWindow的行为,而DataWindow对象则定义了数据的来源、格式和显示方式。Items和Columns则是DataWindow的具体数据元素,用于显示和编辑数据库中的字段。 2. **数据源与查询**:DataWindow的...

    计算机软件-编程源码-PB7.0数据窗口技术详解.zip

    - 静态数据窗口:预先定义了列结构,适用于固定格式的数据展示。 - 动态数据窗口:在运行时根据SQL查询结果动态生成列,适合处理结构不固定的数据库表。 3. **数据窗口设计** - 使用PB7.0的DataWindow Painter...

    Powerbuiler中用OLE控件使用WORD文档

    通过使用 WORD 文档,用户可以自由地修改报表的格式,并且可以设计打印报表的程序。 在 PB 中,数据窗口控件可以快速地开发出一个数据管理系统。但是,在报表的格式方面,用户很难根据需要进行修改。WORD 文档具有...

    免费支票打印软件

    软件中的报表自定义格式功能让你灵活定义报表中的数据内容,可定义无限量次的各种格式,几乎可满足100%的打印要求。 财务小助手之支票进账通功能介绍: 1、适合所有银行支票、进账单打印。不同银行的支票、进账单...

    AC Report开发应用手册.pdf

    AC Report是一款强大的报表设计和生成工具,它支持多种格式的输出,如PDF、Word等,并且能够通过Delphi等多种编程语言进行集成和调用。该工具的主要特点包括但不限于: 1. **灵活的报告设计**:用户可以自由地设计...

    图书管理系统 powerbuild

    PowerBuilder的数据窗口不仅可以用于数据输入和显示,还可以生成复杂格式的报表,并支持预览和打印,满足图书馆的各种统计需求。 5. **用户权限管理**:为了保证系统安全,我们需要对不同角色的用户分配不同的操作...

    Doris介绍、原理、安装、集成hive

    - **自助分析**:分析师可以根据需要自由探索数据,查询模式不固定,但需要较高吞吐量。例如,小米基于Doris构建的增长分析平台(Growing Analytics,GA),利用用户行为数据进行业务增长分析,平均查询延时约为10秒...

    数据库任务书

    3. 数据库管理系统可自由选择,如Oracle、SQL Server、MySQL或Access等,同时可以选择合适的可视化开发工具,如VC、VB、PB、C++Builder、Delphi、C#、.NET或ASP等,开发语言不限,但重点应放在设计而非学习新语言上...

Global site tag (gtag.js) - Google Analytics