• 网络学院
  • IT资讯
  • 操作系统
  • 网络技术
  • 软件应用
  • 办公软件
  • 编程技术
  • 网站架设
  • 数据库类
  • 平面设计
  • 多媒体类
  • 游戏资讯
  • 教学论文
  • 认证考试
用Powerbuilder开发WEB数据库
  站点:
  • 首 页
  • 最新软件
  • 文章教程
  • 国内软件
  • 国外软件
  • 绿色软件
  • 源码下载
  • 字体下载
用Powerbuilder开发WEB数据库
软件发布 用Powerbuilder开发WEB数据库
网络软件 系统工具 应用软件 联络聊天 图形图像 多媒体类 行业软件 游戏娱乐 编程开发 安全相关 教育教学 数码软件 绿软下载
热门软件: QQ 瑞星 pplive e话通 木马克星 千千静听 office2000 五笔字根 Photoshop 视频分割
返回文章教程首页 >> 文章首页 >> 认证考试 >> 系统工程师 >> 用Powerbuilder开发WEB数据库

用Powerbuilder开发WEB数据库

添加时间: 2007-4-11 3:41:10  作者: 系统工程师认证参考  阅读次数:122   来源: http://www.d9soft.com

       

 
 一、引言

  我们知道,现在随着internet应用的不断深化,人们对web服务器所查询的信息就不仅仅限于以文件方式存放于服务器端的静态超文本文件。有时需要借助关系新数据库来存放变化的数据,并在web服务器于数据库服务器之间以cgi等方法建立两者的连接,使web服务器能够实现对数据库的动态的及时的查询,并将最新的数据(结果)返回给浏览器。

  于是在internet应用中就出现了如图1所示的这样一种结构。

 

 

 

 

图1 客户浏览器—web服务器—数据库服务器三级结构

  当然这一结构的实现,用asp等开发 网络 数据库的软件也能够实现,并且正在成为日益流行的趋势,但是对于已经拥有大量用户的pb来说,其对internet的支持就可以让pb用户迅速转移到web的开发上来而不需要再重新学习一门语言。

  另外,我们如果稍稍留心的话就不难发现,现在用pb开发出来的所谓的mis系统千篇一律几乎都是一个模式:用户先登录,进入系统后出现一个mdi窗口,带有数项菜单,菜单下面又有若干菜单,通过菜单打开一个个窗口……当然并不是说这种传统的方式有什么缺点,只是它和当今正日益流行的网页的形式比较起来,还是逊色不少,网页的友好形式更受广大用户的欢迎。而pb的web方式正是迎合了当今internet时代发展的潮流——可以用网页的形式再现pb的传统强大功能。
而且,随着越来越多的企事业单位上网,很多单位不仅仅要有自己的一套mis系统,而且还迫切需要开发自己的网络数据库系统,来向外界更好的宣传自己。这时候一般的选择往往是这两种系统各自独立的开发一套,不可避免地造成了一定程度的浪费。并且这两种系统的开发商是同一家还好,若是两家开发商,那么在不同的时候还要进行不断的协商,这不能不说又是一种浪费。如果能有一种方法可以把两种系统最大限度的把两种系统结合起来,就能够节约各种财力、 人力 和物力,还会大大提高办公效率。
  二、pb6.0/6.5的internet developer toolkit(idt)

  经典的开发工具pb6.0/6.5,对internet支持可以说是它的一个主要特性,可以说这是在idt基础上的一个全新的飞跃。通过将idt(internet developer toolkit)工具集成到pb的开发环境中,通过这些工具,开发人员可以将现有的一些应用移植到internet中,也可以开发新的面向internet的应用。

  在图1所示的的结构下,pb提供了internet应用的两种访问方式。这两种访问方式是:
  ·基于plugin(插入件)的client/server方式

  ·基于web.pb的browser/server方式

  对应于这两种方式,主要是在idt上选择的不同。

  采用pb的idt开发应用的方法和pb的一般应用的开发方法是类似的,通过这些工具,可以将现有的一些应用移植到internet中,也可以开发新的面向internet的应用。

  在pb6.0/6.5中,提供了web.pb、datawindow plug-in、window plug-in和window active等一系列面向internet的工具,每个工具所实现的功能、所依赖的平台都不尽相同。pb的idt主要有三种部件:

  1.datawindow plugin

  使用该plugin可以在ie或者netscape等浏览器中直接查看用powerbuilder的datawindow生成的报表--psr格式的文件。当然不能直接修改了,也不是动态生成的。而是阅读已经生成好并存下来的文件。

  2. window plugin

  这个plugin可就不是仅仅显示静态数据了。它在浏览器中中运行pb生成的child window,而这个child window是包含在pb的动态连接库(pbd)中传送过来的。用起来就象独立的pb程序一样,可以有数据窗口、ole、ocx等各种各样的控制,可以远程操作数据库。可以极大的发挥pb的功能。

  3. web.pb

  web.pb是用来开发基于web应用的基本部件,该部件本身就是web上的一个网关应用程序。该工具提供从 web服务器到powerbuilder应用服务器的访问,允许用户在 internet以及intranet下,通过web对数据库进行近于完全的操纵。同时,通过web.pb,动态创建html文文件亦成为可能。web.pb程序是web服务器和 powerbuilder应用服务器相连接的桥梁。它支持cgi、isapi、nsapi、msapi等多种网关程序接口。

  不管怎么样,必须要明确这样一个结论,pb的internet应用开发是由两个部分组成的,一个是面向服务器的应用程序,主要采用的是web.pb技术。另外一个是面向客户端的技术,包括各种内插件和activex技术。这是两种不同的技术路线,在实施的时候,必须加以充分的考虑。从另外一个角度可以看出,各种内插件和activex技术是为了将现有的应用扩展到internet中去,而web.pb主要是面向新应用的开发。当然这也不是绝对的,plug-in技术照样可以开发新的应用特别是intranet的应用。

  三、开发策略的选择

  1.pb6.5的internet/intranet总体计划实施策略选择

  现在好象一直存在着“瘦客户端”和“胖客户端”的争论,这里不评价这两者的优劣,但是这肯定是实施策略时要考虑到的问题。如果希望采用纯的“瘦客户端”,那么两种pug-in技术和active技术就不是最好的选择。

  采用“瘦客户机” 策略——即web.pb方式,能够减少在客户端软件方面的投资,因为这种瘦客户机一般只需要浏览器这种核心部件。另外,瘦客户机对计算机的性能要求也比较低,不需要客户机承担多少运算的负载,大量的运算任务都由服务器来承担。

  如果采用“中间”策略,那么,可以在客户端加载plug-in和activex(现在的浏览器一般都支持这种技术),并且支持mine格式的内容。这样一来,客户即便能够承担一些表现逻辑方面的任务。但是,业务逻辑的大部分运算任务仍然在服务器端完成。这种其实就是window plug-in方式,它尤其适用于intranet网中。

  最后一种是传统的c/s策略,其实就是“胖客户”方式。由于大部分程序都驻留在客户端,它对客户机的要求也很高。这种方式在现在的intranet中估计迟早要被淘汰。
在具体的idt工具的选择策略上,主要有三个方面的选择:

  1)如果是需要实现客户端访问数据库并在客户机上进行业务处理,最好使用window plug-in,它不仅可以最大限度地发挥pb的强大功能,而且对用户非常友好,告别老套的菜单走向了丰富多彩的网页形式。

  2)如果客户端需要预先编制好的报表,应采用datawindow plug-in为上佳。它能够在浏览器内显示已经生成并存储在web服务器上的psr报表。因为这个报表是预先生成的,所以不需要访问数据库。用户可以在浏览器内查看、打印和保存报表。psr报表的格式多样,能够给www浏览增添不少风采。

  3)如果需要使用集中控制的数据库和业务逻辑程序,那么最好使用web.pb。

  2.开发系统具体策略的考虑及分布式的介绍

  由于要建立的web方式的图书馆系统主要是基于intranet的,结合上面所说的几种考虑,因此大部分应用就采用了window plug-in的方式,这不仅能体现pb一向的强大功能,而且能充分让你去发挥其功能,把mis系统 管理 和丰富多彩的网页结合起来了。

  web服务器用的是 微软 的pws(personal web server),web.pb用的是pbcgi60.exe(表示是cgi标准),sybase数据库,nt平台。

  开发过程中大量使用了数据库连接,单、多条件数据查询以及各种控件的.visible属性,尤其是在tab控件中用到了selectionchanged事件的newindex属性(以便每重新点击一个tabpage可以重新操作而不受以前操作的影响),大大增强了表现效果。

  还要补充一点的是,在建立应用的过程中要注意的一点是不要使用全局对象,特别是在child窗口不能用sqlca作为事物对象(它应该算一个全局变量,window plug-in方式不支持全局变量),一定要重新自定义一个事物对象mytransaction。若使用sqlca单独运行窗口还可以,一旦要在客户端浏览器中出现肯定会报错,而在这儿几乎没有哪本参考书特意强调过,初学者创建自己的应用时很容易在此走弯路。

  以上只算是建立了pb的应用程序,还要做的有:生成.pbd文件并放到web共享目录下;编写html语句嵌入窗口,放到服务器目录下,这里的关键性的html语句是:

<body> <embed src=cgi-pbd/books.pbd width=700 height=600 window=w_bugao> </body>

  web.pb是基于powerbuilder分布式应用技术之上的,web.pb替代了客户端的代理而已。在pb分布式应用中,pb客户应用和pb服务器应用程序之间的对象分布如所图2所示。

图 2

  使用web.pb进行基于服务器的开发,可以让pb建立基于服务器的web应用,允许web浏览器访问分布式pb应用程序的服务。这些分布式的基于服务器的应用程序可以动态生成html页或将html发送到web浏览器。这允许用户支持真正的“瘦”客户机体系,也就是在客户机上只需一个浏览器。这种方式也可以称为纯的browser/server方式。

  如图2所示,客户端通过proxy对象定义服务器应用程序之中的应用对象。而web.pb不同于传统的客户端应用,web.pb不同于传统的客户端应用,web.pb文件取代了客户端的应用程序,起作用相当于访问服务器应用程序的接口。在浏览器中,用户可以访问分布式pb应用程序中的任何不可视对象的属性和方法。用户还可以向方法传递参数。web服务器与web.pb通信将这些信息发送给分布式pb应用程序,应用程序会执行方法并将结果以动态html的形式返回给浏览器。
建立web.pb应用的过程如下:

  a. 建立并测试服务应用(这里是pb_net)

  ·创建应用对象

  ·创建应用启动窗口

  ·创建传输对象

  ·创建不可视用户对象

  ·编写用户对象函数

  b. 编写可调用服务应用的html页面,这可通过frontpage等主页编辑器,也可通过web.pb的编程wizard来做。

  c. 将应用编译成可执行文件。

  d. 编辑web.pb的几个初始化文件

  e. 设置web服务器(主要是文件类型和web目录的设置等)

  f. 启动服务应用和web服务器。

  g. 用浏览器访问应用。

  服务应用的编写和分布式应用类似,就不再赘述。这里需要补充一点的是,编写用户对象是web.pb应用中的头等大事,并且web.pb中的数据窗口一般用的都是datastore。这里创建了一个用户对象uo_pbdemo,实际上用户对象应该尽量要创建的多才好,特别是在那些大型的应用中。

  web.pb方式的应用都是通过html中的锚点anchor(<a>)定义的超链接或者是form(<form>)元素的可输入域中键入信息后单击submit按钮(定义的也有超链接)来激活web.pb实现的。而这些超链接的对象形式上都是指向各个用户对象中的函数的(这些函数的返回值均是一系列的html文文件),这一点务必要明确,其实这一点也是web.pb方式的核心 思想 概念所在。

  这里uo_pbdemo建立了数个函数,挑出颇具代表性的一个的描述如下:

//从数据库中提取新书介绍
//f_retrieve_newbooks()无参数,返回值是string类型的
string ls_html
string ls_search_arg
long ll_rows_retrieved

ds_names = create datastore
ds_names.dataobject="d_newbooks"
ds_names.settransobject(gtr_trans)
ll_rows_retrieved= ds_names.retrieve()
if ll_rows_retrieved > 0 then
ls_html=ds_names.object.datawindow.data.htmltable
else
ls_html = '此次找不到新书!'
end if
return ls_html

  这是非常关键的一段代码,其实就是调用了数据窗口的htmltable属性而已,要知道这种 思想 可以说是贯穿了整个web.pb应用的全过程。

  启动浏览器就可以检索到新书了。当然还有一个前提是:服务器确定是在监听,即刚建立的pb_inet应用必须在运行中。

  最后还要在服务器端配置几个ini文件:hosts文件、services文件和pbweb.ini文件,当然这项工作实际上应该在整个工作之前所做的。

  四、对三种开发方式的总结

  1.关于window plug-in的几点体会

  1)window plug-in最适用于intranet网,前面提到过原因,因为需要浏览器的支持,而且需要在浏览器端安装程序文件。另外一个原因就是,window plug-in主要的执行环境还是浏览器本身所在的本地机环境,只有在内部网的情况下,才能够对应用执行的环境进行比较好的控制,避免出错。

  2)window plug-in适用于在浏览器端有比较复杂的用户接口的情况,可避免编写大量的html和cgi程序。开发internet经常遇到的一个难题就是在客户端没有足够的组件。现在,有了window plug-in,只要愿意,就能把独立的pb应用程序转移到浏览器中来执行。

  3)并且,window plug-in移植和修改现有的应用程序到web上也可以说是不费什么力气,还可以充分享受数据窗口的强大功能。

  4)在intranet环境下, 安全 等因素就不是那么重要了,可允许应用程序访问客户机的磁盘,使用户能够将本地的资源和服务器的资源结合起来应用。

  5)笔者看来,这三种idt中,window plug-in方式是最值得用的。

  2. 关于datawindow plug-in的几点体会

  1)datawindow plug-in可以在web上发布复杂的报表,加快向web用户的发布。

  2)它克服了html的限制,提供复杂的报表,包括列表形式、交叉表形式和图形方式等。

  3)它没有安全限制,因为psr文件是制度的,而这个报表并不在本地
运行。psr报表在浏览器中除了显示之外,只能够运行保存数据和打印两种功能,因此是十分安全的。

  4)datawindow plug-in时静态显示报表的一种方法,无法直接修改这种方法显示的数据和报表格式,但可以在一个中央位置更新报表。

  5)psr格式的报表能够包含多种显示风格的数据窗口,但在datawindow plug-in中,不支持rich text格式的报表。

  3.web.pb构建web应用有如下优点:

  a. 支持cgi、isapi、nsapi、msapi等多种网关程序接口。

  b. 支持powerbuilder中数据窗口的引用。

  c. 易于将以前编写的powerbuilder应用移植到web环境下。

  d. 易于创建嵌入powerbuilder应用程序的html文件,应用服务器在运行环境下,将根据用户需求, 动态生成html语法,发布完全动态的信息。

  e. 支持数据库连接。powerbuilder所能够连接到的数据库都可以被浏览器用户访问到,使得 web服务与数据库服务通过powerbuilder 6.0完整地结合起来。

  另外,谈一点对web.pb的不足之处。虽然说sybase公司极力地让pb支持web方式并且采取了很多方案其中一种就是其引以为豪的web.pb,的确,web.pb在 网络 数据库方面确实有不小的成绩,可以采用集中式数据库 管理 。但它在开发网络数据库方面也绝不会成为流行的趋势,它开发初衷就是主要面对广大pb的老用户的(老用户更容易上手),而且它在页面的开发上过于单调,且不说动态性不强,光是一大堆类库函数,加上每个函数还有数个参数,而且创建页面其实比手写html语言还要辛苦(因为它要返回一个完整的字符串到浏览器)。联想到当今的社会发展非常注重效率,很难设想从头单纯学习pb的idt而仅仅为了编辑过于普通的网页和开发网络数据库。因此在这方面也就是说web.pb广泛推广的价值不大,但是对于已经掌握了pb的开发用户来说,如果不想学习新的语言或工具,用web.pb开发也是一个很好的选择。

  注:虽然当今pb已经发展到8.0版本,但是仍然有很多的开发者依旧用着他们认为是最为经典的6.0/6.5版本。本文基本上是在6.5版本上运行的,笔者认为却一点都不过时,因为友好的web风格的窗口肯定是大势所趋。

 

上下文章:

 

上一篇文章: PowerBuilder制作IE风格的图标按钮 下一篇文章: 在builder中向Excel传递数据

相关文章:

  • Oracle下调数据库许可价格以适应多芯CPU
  • Oracle发布免费数据库管理工具Raptor
  • 甲骨文意外泄漏数据库安全漏洞
  • Oracle认证数据库备份技巧
  • 甲骨文发布数据库新工具·启动内容管理战略

相关软件:

  • Grove[.NET组件开发包] V1.2.1640
  • Access数据库密码破解器 V2.65
  • dbguide 数据库管理专家 V1.3.0.0
  • 网际数据库浏览器 3.0.52
  • NeoExam考试系统 大众版/ACCESS数据库 1.0.8
  • NeoExam考试系统 VIP版/ACCESS数据库 1.0.8

 

快速导航

  • 网络学院
  • 精品汇聚
  • 字体下载
  • 教程下载
  • ASP源码
  • PHP源码
  • Net源码
  • JSP 源码

认证考试分类导航

  • 微软认证
  • 计算机等级考试
  • 软件水平考试
  • 思科认证
  • Oracle认证
  • Linux认证
  • JAVA认证
  • 网络工程师
  • 系统工程师
  • 程序员

本类经典文章推荐

  • SQLServer的安全检查
  • 系统设计师资格与水平考纲 (原高级...
  • 系统分析员备考之ISO9000系列基础...
  • 开发数据库的WEB查询
  • 在builder中向Excel传递数据
  • 用Powerbuilder开发WEB数据库
  • PowerBuilder制作IE风格的图标按钮
  • PowerBuilder编程技巧四则
  • 小议数据库主键选取策略
  • 跨数据库文献检索统一平台的实现

系统工程师阅读排行

  • 数据库原理各章节简答题总结
  • 利用C++Builder6.0开发简单的车辆...
  • 跨数据库文献检索统一平台的实现
  • 用Powerbuilder开发WEB数据库
  • 系统设计师资格与水平考纲 (原高级...
  • 项目进度的黑洞——已完成90%
  • 系统分析员备考之ISO9000系列基础...
  • 小议数据库主键选取策略
  • 数据库系统工程师全真预测试卷(一...
  • 2005年上半年数据库系统工程师上午...

认证考试阅读总排行

  • 全国计算机等级考试一级模拟试题01
  • 全国计算机等级考试一级模拟试题10
  • 全国计算机等级考试一级模拟试题08
  • MCSD简介
  • 全国计算机等级考试一级考试最新模...
  • 全国计算机等级考试一级模拟试题07
  • 全国计算机等级考试一级模拟试题02
  • 全国计算机等级考试一级模拟试题06
  • 全国计算机等级考试一级模拟试题03
  • 一级(WINDOWS)试题解析-Word篇

广告位置

字母检索 A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 回到顶部

关于我们 | 版权声明 | 免责条款 | 广告联系 | 软件发布 | 下载帮助 | 下载排行 | 网站地图 | 特别鸣谢 | 友情连接

copyright; 2005-2008 D9soft.com 第九软件网 版权所有