PB环境下分布式应用程序的开发
敬业的IT人
互联网
佚名
2008-1-4 12:29:54
【内容提要】传统的数据库应用程序经常采用客户机/服务器结构(即C/S结构),这种结构在技术上已经很成熟了并且应用也很广泛,但这种结构的应用系统有其不足之处,比如查询结果无法共享,即使两个客户发出的请求完全相同也要在服务器上执行两次查询;在客户端存储了具有商业价值的查询算法;数据库服务器负担过重导致效率低下等。如果在服务器和客户机之间再加一个服务器,专门用于存储查询算法和临时查询结果,则问题就得到了很好的解决:一方面不同的客户可以共用临时的查询结果而无须再访问数据库服务器,减轻了服务器的负担;同时在客户端也看不到作为商业机密的查询算法。这就是分布式系统的工作原理,本文将介绍如何应用PowerBuilder进行分布式应用程序的开发。
一、分布式应用程序概述
分布式系统的出现源于传统的C/S结构的若干弊病,如效率低,安全性差等,结合到数据库方面来说,全球的DNS(域名解析系统)系统是一个很典型的例子,试想如果把全世界所有的域名都集中到一台服务器中来进行管理,那服务器肯定会因负载过重而无法正常工作,整个互联网也就瘫痪了。
在编写C/S结构的数据库应用系统时,同样也会遇到这类问题,那就是如果客户数量很多,数据量又都很大的情况下,服务器的负载就会很重,而且重复性工作很多,因为很多客户发出的查询可能完全相同而服务器却需要一一进行查询;同时查询算法存储于客户端,这可能不适合一些商业环境,因为算法本身可能是需要保密的。如果能够在传统的服务器和客户机之间再加一个服务器用于存储查询算法和临时查询结果,则以上问题均得到了解决。这正是分布式系统的工作原理。
二、在PB环境下如何进行分布式应用程序的开发
下图是分布式系统的工作原理图:
图(一)
首先,分布式服务器必须建立与数据库服务器的连接,可以通过ODBC接口来实现,本文不在叙述,下面要讲述客户端如何通过分布式服务器来访问数据。
在PB环境下要实现分布式的编程,首先在DTS端,需要用到两个对象,一个TransPort对象和一个不可视的用户对象(Classà Custom,Nborder="0" alt="PB环境下分布式应用程序的开发(图二)" />
- ·应用MFC开发高级应用程序
·在VC++应用程序中读取文本数据
·使用GWT开发AJAX应用程序
·DirectSound应用程序开发快速入门
·在Ajax应用程序中实现数据交换
·用Indy组件开发Socket应用程序
·MFC应用程序框架入门
·VFP基础教程 第十一章 应用
·用VC++建立Service服务应用程序
·用VC++编制FTP客户端应用程序
图(二)

图(三)
该程序的大部分源代码如下:
DTS端:
1、首先定义一个全局变量:Transport mytrans;
2、在"开始监听"按钮中输入如下代码:
long ll
mytrans=create transport
mytrans.driver="winsock"
mytrans.application="5000" //端口号
mytrans.location="." //本地服务器
ll=mytrans.listen() //开始监听
if ll<>0 then
messagebox(string(mytrans.errcode),mytrans.errtext)
return
end if
server.settranspool(12,16,10) //设置连接缓冲,注意"server"为应用的名称
this.text="正在监听中..."
this.enabled=false
3、在"结束监听"按钮中输入如下代码:
mytrans.stoplistening() //结束监听
destroy mytrans
cb_1.text="开始监听"
cb_1.enabled=true
4、建立一个NVO:
利用PB的User Objects画板建立一个classàcustom的用户对象,建立用户对象函数nvoretrieve(ref blob buffer,string filter) returns long,函数体如下:
long ll
SQLCA.DBMS = "ODBC"
SQLCA.AutoCommit = False
SQLCA.DBParm = "Connectstring='DSN=person'"
connect; //建立与数据库的连接
datastore datastore_buffer
datastore_buffer=create datastore
datastore_buffer.dataobject="dw_person" //dw_person是一个数据窗口
datastore_buffer.settransobject(sqlca)
datastore_buffer.retrieve()
datastore_buffer.setfilter(filter)
datastore_buffer.filter()
ll=datastore_buffer.getfullstate(buffer) //函数getfullstate()和setfullstate()常用于分布式应用程序。
disconnect;
return ll
5、建立NVO的代理对象
在用户对象上点鼠标右健,选择"Set Proxy Name",输入"NVO_dw",保存用户对象。
打开Library画板,将"NVO_dw"输出为文件,以便在客户端导入该代理。
Client端:
1、打开Library画板,将刚才输出的文件导入
2、定义两个全局变量:
connection myconn
nvo_dw proxy_dw
3、在"连接"按钮中输入如下代码:
long ll
myconn=create connection
myconn.driver="winsock"
myconn.application="5000" //必须和DTS端的端口号一致
myconn.location="192.168.6.1" //DTS的IP地址
ll=myconn.connecttoserver() //建立连接
if ll<>0 then
messagebox(string(myconn.errcode),myconn.errtext)
return
end if
this.text="正在连接中..."
this.enabled=false
cb_2.enabled=true
cb_3.enabled=true
3、在"断开"按钮中输入如下代码:
myconn.disconnectserver() //断开连接
destroy myconn
cb_1.enabled=true
cb_1.text="连接"
cb_3.enabled=false
this.enabled=false
4、在"查询"按钮中输入如下代码:
long result
blob buffer
myconn.createinstance(proxy_dw) //建立代理对象
result=proxy_dw.nvoretrieve(buffer,"sex='男'") //检索所有男性职工
result=dw_1.setfullstate(buffer) //dw_1是一个数据窗口控件
四、小结及注意事项
1、以上程序在WINDOWS'98、PB6.0环境中调试通过,在客户数量很多,数据量很大的情况下,查询的速度会快很多。
2、编程时注意,如果NVO的函数体发生变化,则无须重新生成代理;如果NVO的函数接口发生变化,则必须重新生成它的代理并将它输入到客户端中。
3、NVO对象是一个不可视对象,只能通过函数调用的方法使用它,不可将它作为一个控件放在窗口上。
- 最新文章
- PB/Sybase系统开发中的数据库转移[01-04]
- PowerBuilder应用开发系列讲座(32)[01-04]
- PowerBuilder应用开发系列讲座(20)[01-04]
- PowerBuilder应用开发系列讲座(14)[01-04]
- 关于PB播放AVI文件的补充[01-04]
- 在PB中应用灵活多样的排序[01-04]
- 相关文章
- PowerBuilder应用开发系列讲座(32)[01-04]
- PowerBuilder应用开发系列讲座(20)[01-04]
- PowerBuilder应用开发系列讲座(14)[01-04]
- 在PB中应用灵活多样的排序[01-04]
- 如何实现PB应用程序的屏幕保护功能[01-04]
- PowerBuilder应用开发系列讲座(16)[01-04]
